You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
6682 lines
204 KiB
6682 lines
204 KiB
3 years ago
|
/*===- TableGen'erated file -------------------------------------*- C++ -*-===*\
|
||
|
|* *|
|
||
|
|* Machine Code Emitter *|
|
||
|
|* *|
|
||
|
|* Automatically generated file, do not edit! *|
|
||
|
|* *|
|
||
|
\*===----------------------------------------------------------------------===*/
|
||
|
|
||
|
uint64_t MipsMCCodeEmitter::getBinaryCodeForInstr(const MCInst &MI,
|
||
|
SmallVectorImpl<MCFixup> &Fixups,
|
||
|
const MCSubtargetInfo &STI) const {
|
||
|
static const uint64_t InstBits[] = {
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2080375378), // ABSQ_S_PH
|
||
|
UINT64_C(4412), // ABSQ_S_PH_MM
|
||
|
UINT64_C(2080374866), // ABSQ_S_QB
|
||
|
UINT64_C(316), // ABSQ_S_QB_MMR2
|
||
|
UINT64_C(2080375890), // ABSQ_S_W
|
||
|
UINT64_C(8508), // ABSQ_S_W_MM
|
||
|
UINT64_C(1409295227), // ABS_D_MMR6
|
||
|
UINT64_C(1409287035), // ABS_S_MMR6
|
||
|
UINT64_C(32), // ADD
|
||
|
UINT64_C(3959422976), // ADDIUPC
|
||
|
UINT64_C(2013265920), // ADDIUPC_MM
|
||
|
UINT64_C(2013265920), // ADDIUPC_MMR6
|
||
|
UINT64_C(27649), // ADDIUR1SP_MM
|
||
|
UINT64_C(27648), // ADDIUR2_MM
|
||
|
UINT64_C(19456), // ADDIUS5_MM
|
||
|
UINT64_C(19457), // ADDIUSP_MM
|
||
|
UINT64_C(805306368), // ADDIU_MMR6
|
||
|
UINT64_C(2080375320), // ADDQH_PH
|
||
|
UINT64_C(77), // ADDQH_PH_MMR2
|
||
|
UINT64_C(2080375448), // ADDQH_R_PH
|
||
|
UINT64_C(1101), // ADDQH_R_PH_MMR2
|
||
|
UINT64_C(2080375960), // ADDQH_R_W
|
||
|
UINT64_C(1165), // ADDQH_R_W_MMR2
|
||
|
UINT64_C(2080375832), // ADDQH_W
|
||
|
UINT64_C(141), // ADDQH_W_MMR2
|
||
|
UINT64_C(2080375440), // ADDQ_PH
|
||
|
UINT64_C(13), // ADDQ_PH_MM
|
||
|
UINT64_C(2080375696), // ADDQ_S_PH
|
||
|
UINT64_C(1037), // ADDQ_S_PH_MM
|
||
|
UINT64_C(2080376208), // ADDQ_S_W
|
||
|
UINT64_C(773), // ADDQ_S_W_MM
|
||
|
UINT64_C(2080375824), // ADDSC
|
||
|
UINT64_C(901), // ADDSC_MM
|
||
|
UINT64_C(2021654544), // ADDS_A_B
|
||
|
UINT64_C(2027946000), // ADDS_A_D
|
||
|
UINT64_C(2023751696), // ADDS_A_H
|
||
|
UINT64_C(2025848848), // ADDS_A_W
|
||
|
UINT64_C(2030043152), // ADDS_S_B
|
||
|
UINT64_C(2036334608), // ADDS_S_D
|
||
|
UINT64_C(2032140304), // ADDS_S_H
|
||
|
UINT64_C(2034237456), // ADDS_S_W
|
||
|
UINT64_C(2038431760), // ADDS_U_B
|
||
|
UINT64_C(2044723216), // ADDS_U_D
|
||
|
UINT64_C(2040528912), // ADDS_U_H
|
||
|
UINT64_C(2042626064), // ADDS_U_W
|
||
|
UINT64_C(1024), // ADDU16_MM
|
||
|
UINT64_C(1024), // ADDU16_MMR6
|
||
|
UINT64_C(2080374808), // ADDUH_QB
|
||
|
UINT64_C(333), // ADDUH_QB_MMR2
|
||
|
UINT64_C(2080374936), // ADDUH_R_QB
|
||
|
UINT64_C(1357), // ADDUH_R_QB_MMR2
|
||
|
UINT64_C(336), // ADDU_MMR6
|
||
|
UINT64_C(2080375312), // ADDU_PH
|
||
|
UINT64_C(269), // ADDU_PH_MMR2
|
||
|
UINT64_C(2080374800), // ADDU_QB
|
||
|
UINT64_C(205), // ADDU_QB_MM
|
||
|
UINT64_C(2080375568), // ADDU_S_PH
|
||
|
UINT64_C(1293), // ADDU_S_PH_MMR2
|
||
|
UINT64_C(2080375056), // ADDU_S_QB
|
||
|
UINT64_C(1229), // ADDU_S_QB_MM
|
||
|
UINT64_C(2013265926), // ADDVI_B
|
||
|
UINT64_C(2019557382), // ADDVI_D
|
||
|
UINT64_C(2015363078), // ADDVI_H
|
||
|
UINT64_C(2017460230), // ADDVI_W
|
||
|
UINT64_C(2013265934), // ADDV_B
|
||
|
UINT64_C(2019557390), // ADDV_D
|
||
|
UINT64_C(2015363086), // ADDV_H
|
||
|
UINT64_C(2017460238), // ADDV_W
|
||
|
UINT64_C(2080375888), // ADDWC
|
||
|
UINT64_C(965), // ADDWC_MM
|
||
|
UINT64_C(2013265936), // ADD_A_B
|
||
|
UINT64_C(2019557392), // ADD_A_D
|
||
|
UINT64_C(2015363088), // ADD_A_H
|
||
|
UINT64_C(2017460240), // ADD_A_W
|
||
|
UINT64_C(272), // ADD_MM
|
||
|
UINT64_C(272), // ADD_MMR6
|
||
|
UINT64_C(536870912), // ADDi
|
||
|
UINT64_C(268435456), // ADDi_MM
|
||
|
UINT64_C(603979776), // ADDiu
|
||
|
UINT64_C(805306368), // ADDiu_MM
|
||
|
UINT64_C(33), // ADDu
|
||
|
UINT64_C(336), // ADDu_MM
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2080375328), // ALIGN
|
||
|
UINT64_C(31), // ALIGN_MMR6
|
||
|
UINT64_C(3961454592), // ALUIPC
|
||
|
UINT64_C(2015297536), // ALUIPC_MMR6
|
||
|
UINT64_C(36), // AND
|
||
|
UINT64_C(17536), // AND16_MM
|
||
|
UINT64_C(17409), // AND16_MMR6
|
||
|
UINT64_C(36), // AND64
|
||
|
UINT64_C(11264), // ANDI16_MM
|
||
|
UINT64_C(11264), // ANDI16_MMR6
|
||
|
UINT64_C(2013265920), // ANDI_B
|
||
|
UINT64_C(3489660928), // ANDI_MMR6
|
||
|
UINT64_C(592), // AND_MM
|
||
|
UINT64_C(592), // AND_MMR6
|
||
|
UINT64_C(2013265950), // AND_V
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(805306368), // ANDi
|
||
|
UINT64_C(805306368), // ANDi64
|
||
|
UINT64_C(3489660928), // ANDi_MM
|
||
|
UINT64_C(2080374833), // APPEND
|
||
|
UINT64_C(2046820369), // ASUB_S_B
|
||
|
UINT64_C(2053111825), // ASUB_S_D
|
||
|
UINT64_C(2048917521), // ASUB_S_H
|
||
|
UINT64_C(2051014673), // ASUB_S_W
|
||
|
UINT64_C(2055208977), // ASUB_U_B
|
||
|
UINT64_C(2061500433), // ASUB_U_D
|
||
|
UINT64_C(2057306129), // ASUB_U_H
|
||
|
UINT64_C(2059403281), // ASUB_U_W
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(1006632960), // AUI
|
||
|
UINT64_C(3961389056), // AUIPC
|
||
|
UINT64_C(2015232000), // AUIPC_MMR6
|
||
|
UINT64_C(268435456), // AUI_MMR6
|
||
|
UINT64_C(2063597584), // AVER_S_B
|
||
|
UINT64_C(2069889040), // AVER_S_D
|
||
|
UINT64_C(2065694736), // AVER_S_H
|
||
|
UINT64_C(2067791888), // AVER_S_W
|
||
|
UINT64_C(2071986192), // AVER_U_B
|
||
|
UINT64_C(2078277648), // AVER_U_D
|
||
|
UINT64_C(2074083344), // AVER_U_H
|
||
|
UINT64_C(2076180496), // AVER_U_W
|
||
|
UINT64_C(2046820368), // AVE_S_B
|
||
|
UINT64_C(2053111824), // AVE_S_D
|
||
|
UINT64_C(2048917520), // AVE_S_H
|
||
|
UINT64_C(2051014672), // AVE_S_W
|
||
|
UINT64_C(2055208976), // AVE_U_B
|
||
|
UINT64_C(2061500432), // AVE_U_D
|
||
|
UINT64_C(2057306128), // AVE_U_H
|
||
|
UINT64_C(2059403280), // AVE_U_W
|
||
|
UINT64_C(4026550272), // AddiuRxImmX16
|
||
|
UINT64_C(4026533888), // AddiuRxPcImmX16
|
||
|
UINT64_C(18432), // AddiuRxRxImm16
|
||
|
UINT64_C(4026550272), // AddiuRxRxImmX16
|
||
|
UINT64_C(4026548224), // AddiuRxRyOffMemX16
|
||
|
UINT64_C(25344), // AddiuSpImm16
|
||
|
UINT64_C(4026544896), // AddiuSpImmX16
|
||
|
UINT64_C(57345), // AdduRxRyRz16
|
||
|
UINT64_C(59404), // AndRxRxRy16
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(52224), // B16_MM
|
||
|
UINT64_C(1879048232), // BADDu
|
||
|
UINT64_C(68222976), // BAL
|
||
|
UINT64_C(3892314112), // BALC
|
||
|
UINT64_C(3019898880), // BALC_MMR6
|
||
|
UINT64_C(2080375857), // BALIGN
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(3355443200), // BBIT0
|
||
|
UINT64_C(3623878656), // BBIT032
|
||
|
UINT64_C(3892314112), // BBIT1
|
||
|
UINT64_C(4160749568), // BBIT132
|
||
|
UINT64_C(3355443200), // BC
|
||
|
UINT64_C(52224), // BC16_MMR6
|
||
|
UINT64_C(1159725056), // BC1EQZ
|
||
|
UINT64_C(1157627904), // BC1F
|
||
|
UINT64_C(1157758976), // BC1FL
|
||
|
UINT64_C(1132462080), // BC1F_MM
|
||
|
UINT64_C(1168113664), // BC1NEZ
|
||
|
UINT64_C(1157693440), // BC1T
|
||
|
UINT64_C(1157824512), // BC1TL
|
||
|
UINT64_C(1134559232), // BC1T_MM
|
||
|
UINT64_C(1226833920), // BC2EQZ
|
||
|
UINT64_C(1235222528), // BC2NEZ
|
||
|
UINT64_C(2045771785), // BCLRI_B
|
||
|
UINT64_C(2038431753), // BCLRI_D
|
||
|
UINT64_C(2044723209), // BCLRI_H
|
||
|
UINT64_C(2042626057), // BCLRI_W
|
||
|
UINT64_C(2038431757), // BCLR_B
|
||
|
UINT64_C(2044723213), // BCLR_D
|
||
|
UINT64_C(2040528909), // BCLR_H
|
||
|
UINT64_C(2042626061), // BCLR_W
|
||
|
UINT64_C(2483027968), // BC_MMR6
|
||
|
UINT64_C(268435456), // BEQ
|
||
|
UINT64_C(268435456), // BEQ64
|
||
|
UINT64_C(536870912), // BEQC
|
||
|
UINT64_C(1342177280), // BEQL
|
||
|
UINT64_C(35840), // BEQZ16_MM
|
||
|
UINT64_C(536870912), // BEQZALC
|
||
|
UINT64_C(1946157056), // BEQZALC_MMR6
|
||
|
UINT64_C(3623878656), // BEQZC
|
||
|
UINT64_C(35840), // BEQZC16_MMR6
|
||
|
UINT64_C(1088421888), // BEQZC_MM
|
||
|
UINT64_C(2483027968), // BEQ_MM
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(1476395008), // BGEC
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(402653184), // BGEUC
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(67174400), // BGEZ
|
||
|
UINT64_C(67174400), // BGEZ64
|
||
|
UINT64_C(68222976), // BGEZAL
|
||
|
UINT64_C(402653184), // BGEZALC
|
||
|
UINT64_C(3221225472), // BGEZALC_MMR6
|
||
|
UINT64_C(68354048), // BGEZALL
|
||
|
UINT64_C(1113587712), // BGEZALS_MM
|
||
|
UINT64_C(1080033280), // BGEZAL_MM
|
||
|
UINT64_C(1476395008), // BGEZC
|
||
|
UINT64_C(67305472), // BGEZL
|
||
|
UINT64_C(1077936128), // BGEZ_MM
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(469762048), // BGTZ
|
||
|
UINT64_C(469762048), // BGTZ64
|
||
|
UINT64_C(469762048), // BGTZALC
|
||
|
UINT64_C(3758096384), // BGTZALC_MMR6
|
||
|
UINT64_C(1543503872), // BGTZC
|
||
|
UINT64_C(1543503872), // BGTZL
|
||
|
UINT64_C(1086324736), // BGTZ_MM
|
||
|
UINT64_C(2070937609), // BINSLI_B
|
||
|
UINT64_C(2063597577), // BINSLI_D
|
||
|
UINT64_C(2069889033), // BINSLI_H
|
||
|
UINT64_C(2067791881), // BINSLI_W
|
||
|
UINT64_C(2063597581), // BINSL_B
|
||
|
UINT64_C(2069889037), // BINSL_D
|
||
|
UINT64_C(2065694733), // BINSL_H
|
||
|
UINT64_C(2067791885), // BINSL_W
|
||
|
UINT64_C(2079326217), // BINSRI_B
|
||
|
UINT64_C(2071986185), // BINSRI_D
|
||
|
UINT64_C(2078277641), // BINSRI_H
|
||
|
UINT64_C(2076180489), // BINSRI_W
|
||
|
UINT64_C(2071986189), // BINSR_B
|
||
|
UINT64_C(2078277645), // BINSR_D
|
||
|
UINT64_C(2074083341), // BINSR_H
|
||
|
UINT64_C(2076180493), // BINSR_W
|
||
|
UINT64_C(2080376530), // BITREV
|
||
|
UINT64_C(2080374816), // BITSWAP
|
||
|
UINT64_C(2876), // BITSWAP_MMR6
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(402653184), // BLEZ
|
||
|
UINT64_C(402653184), // BLEZ64
|
||
|
UINT64_C(402653184), // BLEZALC
|
||
|
UINT64_C(3221225472), // BLEZALC_MMR6
|
||
|
UINT64_C(1476395008), // BLEZC
|
||
|
UINT64_C(1476395008), // BLEZL
|
||
|
UINT64_C(1082130432), // BLEZ_MM
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(1543503872), // BLTC
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(469762048), // BLTUC
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(67108864), // BLTZ
|
||
|
UINT64_C(67108864), // BLTZ64
|
||
|
UINT64_C(68157440), // BLTZAL
|
||
|
UINT64_C(469762048), // BLTZALC
|
||
|
UINT64_C(3758096384), // BLTZALC_MMR6
|
||
|
UINT64_C(68288512), // BLTZALL
|
||
|
UINT64_C(1109393408), // BLTZALS_MM
|
||
|
UINT64_C(1075838976), // BLTZAL_MM
|
||
|
UINT64_C(1543503872), // BLTZC
|
||
|
UINT64_C(67239936), // BLTZL
|
||
|
UINT64_C(1073741824), // BLTZ_MM
|
||
|
UINT64_C(2013265921), // BMNZI_B
|
||
|
UINT64_C(2021654558), // BMNZ_V
|
||
|
UINT64_C(2030043137), // BMZI_B
|
||
|
UINT64_C(2023751710), // BMZ_V
|
||
|
UINT64_C(335544320), // BNE
|
||
|
UINT64_C(335544320), // BNE64
|
||
|
UINT64_C(1610612736), // BNEC
|
||
|
UINT64_C(2062549001), // BNEGI_B
|
||
|
UINT64_C(2055208969), // BNEGI_D
|
||
|
UINT64_C(2061500425), // BNEGI_H
|
||
|
UINT64_C(2059403273), // BNEGI_W
|
||
|
UINT64_C(2055208973), // BNEG_B
|
||
|
UINT64_C(2061500429), // BNEG_D
|
||
|
UINT64_C(2057306125), // BNEG_H
|
||
|
UINT64_C(2059403277), // BNEG_W
|
||
|
UINT64_C(1409286144), // BNEL
|
||
|
UINT64_C(44032), // BNEZ16_MM
|
||
|
UINT64_C(1610612736), // BNEZALC
|
||
|
UINT64_C(2080374784), // BNEZALC_MMR6
|
||
|
UINT64_C(4160749568), // BNEZC
|
||
|
UINT64_C(44032), // BNEZC16_MMR6
|
||
|
UINT64_C(1084227584), // BNEZC_MM
|
||
|
UINT64_C(3019898880), // BNE_MM
|
||
|
UINT64_C(1610612736), // BNVC
|
||
|
UINT64_C(1199570944), // BNZ_B
|
||
|
UINT64_C(1205862400), // BNZ_D
|
||
|
UINT64_C(1201668096), // BNZ_H
|
||
|
UINT64_C(1172307968), // BNZ_V
|
||
|
UINT64_C(1203765248), // BNZ_W
|
||
|
UINT64_C(536870912), // BOVC
|
||
|
UINT64_C(68943872), // BPOSGE32
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(13), // BREAK
|
||
|
UINT64_C(18048), // BREAK16_MM
|
||
|
UINT64_C(17435), // BREAK16_MMR6
|
||
|
UINT64_C(7), // BREAK_MM
|
||
|
UINT64_C(7), // BREAK_MMR6
|
||
|
UINT64_C(2046820353), // BSELI_B
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2025848862), // BSEL_V
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2054160393), // BSETI_B
|
||
|
UINT64_C(2046820361), // BSETI_D
|
||
|
UINT64_C(2053111817), // BSETI_H
|
||
|
UINT64_C(2051014665), // BSETI_W
|
||
|
UINT64_C(2046820365), // BSET_B
|
||
|
UINT64_C(2053111821), // BSET_D
|
||
|
UINT64_C(2048917517), // BSET_H
|
||
|
UINT64_C(2051014669), // BSET_W
|
||
|
UINT64_C(1191182336), // BZ_B
|
||
|
UINT64_C(1197473792), // BZ_D
|
||
|
UINT64_C(1193279488), // BZ_H
|
||
|
UINT64_C(1163919360), // BZ_V
|
||
|
UINT64_C(1195376640), // BZ_W
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(8192), // BeqzRxImm16
|
||
|
UINT64_C(4026540032), // BeqzRxImmX16
|
||
|
UINT64_C(4096), // Bimm16
|
||
|
UINT64_C(4026535936), // BimmX16
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(10240), // BnezRxImm16
|
||
|
UINT64_C(4026542080), // BnezRxImmX16
|
||
|
UINT64_C(59397), // Break16
|
||
|
UINT64_C(24576), // Bteqz16
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(4026544128), // BteqzX16
|
||
|
UINT64_C(24832), // Btnez16
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(4026544384), // BtnezX16
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(3154116608), // CACHE
|
||
|
UINT64_C(2080374811), // CACHEE
|
||
|
UINT64_C(1610655232), // CACHEE_MM
|
||
|
UINT64_C(1610655232), // CACHEE_MMR6
|
||
|
UINT64_C(536895488), // CACHE_MM
|
||
|
UINT64_C(536895488), // CACHE_MMR6
|
||
|
UINT64_C(2080374821), // CACHE_R6
|
||
|
UINT64_C(1176502282), // CEIL_L_D64
|
||
|
UINT64_C(1409307451), // CEIL_L_D_MMR6
|
||
|
UINT64_C(1174405130), // CEIL_L_S
|
||
|
UINT64_C(1409291067), // CEIL_L_S_MMR6
|
||
|
UINT64_C(1176502286), // CEIL_W_D32
|
||
|
UINT64_C(1176502286), // CEIL_W_D64
|
||
|
UINT64_C(1409309499), // CEIL_W_D_MMR6
|
||
|
UINT64_C(1409309499), // CEIL_W_MM
|
||
|
UINT64_C(1174405134), // CEIL_W_S
|
||
|
UINT64_C(1409293115), // CEIL_W_S_MM
|
||
|
UINT64_C(1409293115), // CEIL_W_S_MMR6
|
||
|
UINT64_C(2013265927), // CEQI_B
|
||
|
UINT64_C(2019557383), // CEQI_D
|
||
|
UINT64_C(2015363079), // CEQI_H
|
||
|
UINT64_C(2017460231), // CEQI_W
|
||
|
UINT64_C(2013265935), // CEQ_B
|
||
|
UINT64_C(2019557391), // CEQ_D
|
||
|
UINT64_C(2015363087), // CEQ_H
|
||
|
UINT64_C(2017460239), // CEQ_W
|
||
|
UINT64_C(1145044992), // CFC1
|
||
|
UINT64_C(1409290299), // CFC1_MM
|
||
|
UINT64_C(2021523481), // CFCMSA
|
||
|
UINT64_C(1879048242), // CINS
|
||
|
UINT64_C(1879048243), // CINS32
|
||
|
UINT64_C(1176502299), // CLASS_D
|
||
|
UINT64_C(1409286752), // CLASS_D_MMR6
|
||
|
UINT64_C(1174405147), // CLASS_S
|
||
|
UINT64_C(1409286240), // CLASS_S_MMR6
|
||
|
UINT64_C(2046820359), // CLEI_S_B
|
||
|
UINT64_C(2053111815), // CLEI_S_D
|
||
|
UINT64_C(2048917511), // CLEI_S_H
|
||
|
UINT64_C(2051014663), // CLEI_S_W
|
||
|
UINT64_C(2055208967), // CLEI_U_B
|
||
|
UINT64_C(2061500423), // CLEI_U_D
|
||
|
UINT64_C(2057306119), // CLEI_U_H
|
||
|
UINT64_C(2059403271), // CLEI_U_W
|
||
|
UINT64_C(2046820367), // CLE_S_B
|
||
|
UINT64_C(2053111823), // CLE_S_D
|
||
|
UINT64_C(2048917519), // CLE_S_H
|
||
|
UINT64_C(2051014671), // CLE_S_W
|
||
|
UINT64_C(2055208975), // CLE_U_B
|
||
|
UINT64_C(2061500431), // CLE_U_D
|
||
|
UINT64_C(2057306127), // CLE_U_H
|
||
|
UINT64_C(2059403279), // CLE_U_W
|
||
|
UINT64_C(1879048225), // CLO
|
||
|
UINT64_C(19260), // CLO_MM
|
||
|
UINT64_C(19260), // CLO_MMR6
|
||
|
UINT64_C(81), // CLO_R6
|
||
|
UINT64_C(2030043143), // CLTI_S_B
|
||
|
UINT64_C(2036334599), // CLTI_S_D
|
||
|
UINT64_C(2032140295), // CLTI_S_H
|
||
|
UINT64_C(2034237447), // CLTI_S_W
|
||
|
UINT64_C(2038431751), // CLTI_U_B
|
||
|
UINT64_C(2044723207), // CLTI_U_D
|
||
|
UINT64_C(2040528903), // CLTI_U_H
|
||
|
UINT64_C(2042626055), // CLTI_U_W
|
||
|
UINT64_C(2030043151), // CLT_S_B
|
||
|
UINT64_C(2036334607), // CLT_S_D
|
||
|
UINT64_C(2032140303), // CLT_S_H
|
||
|
UINT64_C(2034237455), // CLT_S_W
|
||
|
UINT64_C(2038431759), // CLT_U_B
|
||
|
UINT64_C(2044723215), // CLT_U_D
|
||
|
UINT64_C(2040528911), // CLT_U_H
|
||
|
UINT64_C(2042626063), // CLT_U_W
|
||
|
UINT64_C(1879048224), // CLZ
|
||
|
UINT64_C(23356), // CLZ_MM
|
||
|
UINT64_C(80), // CLZ_MMR6
|
||
|
UINT64_C(80), // CLZ_R6
|
||
|
UINT64_C(2080376337), // CMPGDU_EQ_QB
|
||
|
UINT64_C(2080376465), // CMPGDU_LE_QB
|
||
|
UINT64_C(2080376401), // CMPGDU_LT_QB
|
||
|
UINT64_C(2080375057), // CMPGU_EQ_QB
|
||
|
UINT64_C(2080375185), // CMPGU_LE_QB
|
||
|
UINT64_C(2080375121), // CMPGU_LT_QB
|
||
|
UINT64_C(2080374801), // CMPU_EQ_QB
|
||
|
UINT64_C(2080374929), // CMPU_LE_QB
|
||
|
UINT64_C(2080374865), // CMPU_LT_QB
|
||
|
UINT64_C(1409286165), // CMP_AF_D_MMR6
|
||
|
UINT64_C(1409286149), // CMP_AF_S_MMR6
|
||
|
UINT64_C(1184890882), // CMP_EQ_D
|
||
|
UINT64_C(1409286293), // CMP_EQ_D_MMR6
|
||
|
UINT64_C(2080375313), // CMP_EQ_PH
|
||
|
UINT64_C(1182793730), // CMP_EQ_S
|
||
|
UINT64_C(1409286277), // CMP_EQ_S_MMR6
|
||
|
UINT64_C(1184890880), // CMP_F_D
|
||
|
UINT64_C(1182793728), // CMP_F_S
|
||
|
UINT64_C(1184890886), // CMP_LE_D
|
||
|
UINT64_C(1409286549), // CMP_LE_D_MMR6
|
||
|
UINT64_C(2080375441), // CMP_LE_PH
|
||
|
UINT64_C(1182793734), // CMP_LE_S
|
||
|
UINT64_C(1409286533), // CMP_LE_S_MMR6
|
||
|
UINT64_C(1184890884), // CMP_LT_D
|
||
|
UINT64_C(1409286421), // CMP_LT_D_MMR6
|
||
|
UINT64_C(2080375377), // CMP_LT_PH
|
||
|
UINT64_C(1182793732), // CMP_LT_S
|
||
|
UINT64_C(1409286405), // CMP_LT_S_MMR6
|
||
|
UINT64_C(1184890888), // CMP_SAF_D
|
||
|
UINT64_C(1409286677), // CMP_SAF_D_MMR6
|
||
|
UINT64_C(1182793736), // CMP_SAF_S
|
||
|
UINT64_C(1409286661), // CMP_SAF_S_MMR6
|
||
|
UINT64_C(1184890890), // CMP_SEQ_D
|
||
|
UINT64_C(1409286805), // CMP_SEQ_D_MMR6
|
||
|
UINT64_C(1182793738), // CMP_SEQ_S
|
||
|
UINT64_C(1409286789), // CMP_SEQ_S_MMR6
|
||
|
UINT64_C(1184890894), // CMP_SLE_D
|
||
|
UINT64_C(1409287061), // CMP_SLE_D_MMR6
|
||
|
UINT64_C(1182793742), // CMP_SLE_S
|
||
|
UINT64_C(1409287045), // CMP_SLE_S_MMR6
|
||
|
UINT64_C(1184890892), // CMP_SLT_D
|
||
|
UINT64_C(1409286933), // CMP_SLT_D_MMR6
|
||
|
UINT64_C(1182793740), // CMP_SLT_S
|
||
|
UINT64_C(1409286917), // CMP_SLT_S_MMR6
|
||
|
UINT64_C(1184890891), // CMP_SUEQ_D
|
||
|
UINT64_C(1409286869), // CMP_SUEQ_D_MMR6
|
||
|
UINT64_C(1182793739), // CMP_SUEQ_S
|
||
|
UINT64_C(1409286853), // CMP_SUEQ_S_MMR6
|
||
|
UINT64_C(1184890895), // CMP_SULE_D
|
||
|
UINT64_C(1409287125), // CMP_SULE_D_MMR6
|
||
|
UINT64_C(1182793743), // CMP_SULE_S
|
||
|
UINT64_C(1409287109), // CMP_SULE_S_MMR6
|
||
|
UINT64_C(1184890893), // CMP_SULT_D
|
||
|
UINT64_C(1409286997), // CMP_SULT_D_MMR6
|
||
|
UINT64_C(1182793741), // CMP_SULT_S
|
||
|
UINT64_C(1409286981), // CMP_SULT_S_MMR6
|
||
|
UINT64_C(1184890889), // CMP_SUN_D
|
||
|
UINT64_C(1409286741), // CMP_SUN_D_MMR6
|
||
|
UINT64_C(1182793737), // CMP_SUN_S
|
||
|
UINT64_C(1409286725), // CMP_SUN_S_MMR6
|
||
|
UINT64_C(1184890883), // CMP_UEQ_D
|
||
|
UINT64_C(1409286357), // CMP_UEQ_D_MMR6
|
||
|
UINT64_C(1182793731), // CMP_UEQ_S
|
||
|
UINT64_C(1409286341), // CMP_UEQ_S_MMR6
|
||
|
UINT64_C(1184890887), // CMP_ULE_D
|
||
|
UINT64_C(1409286613), // CMP_ULE_D_MMR6
|
||
|
UINT64_C(1182793735), // CMP_ULE_S
|
||
|
UINT64_C(1409286597), // CMP_ULE_S_MMR6
|
||
|
UINT64_C(1184890885), // CMP_ULT_D
|
||
|
UINT64_C(1409286485), // CMP_ULT_D_MMR6
|
||
|
UINT64_C(1182793733), // CMP_ULT_S
|
||
|
UINT64_C(1409286469), // CMP_ULT_S_MMR6
|
||
|
UINT64_C(1184890881), // CMP_UN_D
|
||
|
UINT64_C(1409286229), // CMP_UN_D_MMR6
|
||
|
UINT64_C(1182793729), // CMP_UN_S
|
||
|
UINT64_C(1409286213), // CMP_UN_S_MMR6
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2021654553), // COPY_S_B
|
||
|
UINT64_C(2025324569), // COPY_S_D
|
||
|
UINT64_C(2023751705), // COPY_S_H
|
||
|
UINT64_C(2024800281), // COPY_S_W
|
||
|
UINT64_C(2025848857), // COPY_U_B
|
||
|
UINT64_C(2027946009), // COPY_U_H
|
||
|
UINT64_C(2028994585), // COPY_U_W
|
||
|
UINT64_C(1153433600), // CTC1
|
||
|
UINT64_C(1409292347), // CTC1_MM
|
||
|
UINT64_C(2017329177), // CTCMSA
|
||
|
UINT64_C(1174405153), // CVT_D32_S
|
||
|
UINT64_C(1182793761), // CVT_D32_W
|
||
|
UINT64_C(1409299323), // CVT_D32_W_MM
|
||
|
UINT64_C(1184890913), // CVT_D64_L
|
||
|
UINT64_C(1174405153), // CVT_D64_S
|
||
|
UINT64_C(1182793761), // CVT_D64_W
|
||
|
UINT64_C(1409307515), // CVT_D_L_MMR6
|
||
|
UINT64_C(1409291131), // CVT_D_S_MM
|
||
|
UINT64_C(1409291131), // CVT_D_S_MMR6
|
||
|
UINT64_C(1409299323), // CVT_D_W_MMR6
|
||
|
UINT64_C(1176502309), // CVT_L_D64
|
||
|
UINT64_C(1409302843), // CVT_L_D64_MM
|
||
|
UINT64_C(1409302843), // CVT_L_D_MMR6
|
||
|
UINT64_C(1174405157), // CVT_L_S
|
||
|
UINT64_C(1409286459), // CVT_L_S_MM
|
||
|
UINT64_C(1409286459), // CVT_L_S_MMR6
|
||
|
UINT64_C(1176502304), // CVT_S_D32
|
||
|
UINT64_C(1409293179), // CVT_S_D32_MM
|
||
|
UINT64_C(1176502304), // CVT_S_D64
|
||
|
UINT64_C(1409293179), // CVT_S_D_MMR6
|
||
|
UINT64_C(1184890912), // CVT_S_L
|
||
|
UINT64_C(1409309563), // CVT_S_L_MMR6
|
||
|
UINT64_C(1182793760), // CVT_S_W
|
||
|
UINT64_C(1409301371), // CVT_S_W_MM
|
||
|
UINT64_C(1409301371), // CVT_S_W_MMR6
|
||
|
UINT64_C(1176502308), // CVT_W_D32
|
||
|
UINT64_C(1176502308), // CVT_W_D64
|
||
|
UINT64_C(1409304891), // CVT_W_D_MMR6
|
||
|
UINT64_C(1409304891), // CVT_W_MM
|
||
|
UINT64_C(1174405156), // CVT_W_S
|
||
|
UINT64_C(1409288507), // CVT_W_S_MM
|
||
|
UINT64_C(1409288507), // CVT_W_S_MMR6
|
||
|
UINT64_C(1176502322), // C_EQ_D32
|
||
|
UINT64_C(1176502322), // C_EQ_D64
|
||
|
UINT64_C(1174405170), // C_EQ_S
|
||
|
UINT64_C(1176502320), // C_F_D32
|
||
|
UINT64_C(1176502320), // C_F_D64
|
||
|
UINT64_C(1174405168), // C_F_S
|
||
|
UINT64_C(1176502334), // C_LE_D32
|
||
|
UINT64_C(1176502334), // C_LE_D64
|
||
|
UINT64_C(1174405182), // C_LE_S
|
||
|
UINT64_C(1176502332), // C_LT_D32
|
||
|
UINT64_C(1176502332), // C_LT_D64
|
||
|
UINT64_C(1174405180), // C_LT_S
|
||
|
UINT64_C(1176502333), // C_NGE_D32
|
||
|
UINT64_C(1176502333), // C_NGE_D64
|
||
|
UINT64_C(1174405181), // C_NGE_S
|
||
|
UINT64_C(1176502329), // C_NGLE_D32
|
||
|
UINT64_C(1176502329), // C_NGLE_D64
|
||
|
UINT64_C(1174405177), // C_NGLE_S
|
||
|
UINT64_C(1176502331), // C_NGL_D32
|
||
|
UINT64_C(1176502331), // C_NGL_D64
|
||
|
UINT64_C(1174405179), // C_NGL_S
|
||
|
UINT64_C(1176502335), // C_NGT_D32
|
||
|
UINT64_C(1176502335), // C_NGT_D64
|
||
|
UINT64_C(1174405183), // C_NGT_S
|
||
|
UINT64_C(1176502326), // C_OLE_D32
|
||
|
UINT64_C(1176502326), // C_OLE_D64
|
||
|
UINT64_C(1174405174), // C_OLE_S
|
||
|
UINT64_C(1176502324), // C_OLT_D32
|
||
|
UINT64_C(1176502324), // C_OLT_D64
|
||
|
UINT64_C(1174405172), // C_OLT_S
|
||
|
UINT64_C(1176502330), // C_SEQ_D32
|
||
|
UINT64_C(1176502330), // C_SEQ_D64
|
||
|
UINT64_C(1174405178), // C_SEQ_S
|
||
|
UINT64_C(1176502328), // C_SF_D32
|
||
|
UINT64_C(1176502328), // C_SF_D64
|
||
|
UINT64_C(1174405176), // C_SF_S
|
||
|
UINT64_C(1176502323), // C_UEQ_D32
|
||
|
UINT64_C(1176502323), // C_UEQ_D64
|
||
|
UINT64_C(1174405171), // C_UEQ_S
|
||
|
UINT64_C(1176502327), // C_ULE_D32
|
||
|
UINT64_C(1176502327), // C_ULE_D64
|
||
|
UINT64_C(1174405175), // C_ULE_S
|
||
|
UINT64_C(1176502325), // C_ULT_D32
|
||
|
UINT64_C(1176502325), // C_ULT_D64
|
||
|
UINT64_C(1174405173), // C_ULT_S
|
||
|
UINT64_C(1176502321), // C_UN_D32
|
||
|
UINT64_C(1176502321), // C_UN_D64
|
||
|
UINT64_C(1174405169), // C_UN_S
|
||
|
UINT64_C(59402), // CmpRxRy16
|
||
|
UINT64_C(28672), // CmpiRxImm16
|
||
|
UINT64_C(4026560512), // CmpiRxImmX16
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(44), // DADD
|
||
|
UINT64_C(1610612736), // DADDi
|
||
|
UINT64_C(1677721600), // DADDiu
|
||
|
UINT64_C(45), // DADDu
|
||
|
UINT64_C(67502080), // DAHI
|
||
|
UINT64_C(1109393408), // DAHI_MM64R6
|
||
|
UINT64_C(2080375332), // DALIGN
|
||
|
UINT64_C(1476395036), // DALIGN_MM64R6
|
||
|
UINT64_C(69074944), // DATI
|
||
|
UINT64_C(1107296256), // DATI_MM64R6
|
||
|
UINT64_C(1946157056), // DAUI
|
||
|
UINT64_C(4026531840), // DAUI_MM64R6
|
||
|
UINT64_C(2080374820), // DBITSWAP
|
||
|
UINT64_C(1879048229), // DCLO
|
||
|
UINT64_C(83), // DCLO_R6
|
||
|
UINT64_C(1879048228), // DCLZ
|
||
|
UINT64_C(82), // DCLZ_R6
|
||
|
UINT64_C(158), // DDIV
|
||
|
UINT64_C(159), // DDIVU
|
||
|
UINT64_C(1476395416), // DDIVU_MM64R6
|
||
|
UINT64_C(1476395288), // DDIV_MM64R6
|
||
|
UINT64_C(1107296287), // DERET
|
||
|
UINT64_C(58236), // DERET_MM
|
||
|
UINT64_C(58236), // DERET_MMR6
|
||
|
UINT64_C(2080374787), // DEXT
|
||
|
UINT64_C(2080374785), // DEXTM
|
||
|
UINT64_C(1476395044), // DEXTM_MM64R6
|
||
|
UINT64_C(2080374786), // DEXTU
|
||
|
UINT64_C(1476395028), // DEXTU_MM64R6
|
||
|
UINT64_C(1476395052), // DEXT_MM64R6
|
||
|
UINT64_C(1096835072), // DI
|
||
|
UINT64_C(2080374791), // DINS
|
||
|
UINT64_C(2080374789), // DINSM
|
||
|
UINT64_C(2080374790), // DINSU
|
||
|
UINT64_C(154), // DIV
|
||
|
UINT64_C(155), // DIVU
|
||
|
UINT64_C(408), // DIVU_MMR6
|
||
|
UINT64_C(280), // DIV_MMR6
|
||
|
UINT64_C(2046820370), // DIV_S_B
|
||
|
UINT64_C(2053111826), // DIV_S_D
|
||
|
UINT64_C(2048917522), // DIV_S_H
|
||
|
UINT64_C(2051014674), // DIV_S_W
|
||
|
UINT64_C(2055208978), // DIV_U_B
|
||
|
UINT64_C(2061500434), // DIV_U_D
|
||
|
UINT64_C(2057306130), // DIV_U_H
|
||
|
UINT64_C(2059403282), // DIV_U_W
|
||
|
UINT64_C(18300), // DI_MM
|
||
|
UINT64_C(18300), // DI_MMR6
|
||
|
UINT64_C(21), // DLSA
|
||
|
UINT64_C(21), // DLSA_R6
|
||
|
UINT64_C(1075838976), // DMFC0
|
||
|
UINT64_C(1142947840), // DMFC1
|
||
|
UINT64_C(1210056704), // DMFC2
|
||
|
UINT64_C(1210056704), // DMFC2_OCTEON
|
||
|
UINT64_C(222), // DMOD
|
||
|
UINT64_C(223), // DMODU
|
||
|
UINT64_C(1476395480), // DMODU_MM64R6
|
||
|
UINT64_C(1476395352), // DMOD_MM64R6
|
||
|
UINT64_C(1084227584), // DMTC0
|
||
|
UINT64_C(1151336448), // DMTC1
|
||
|
UINT64_C(1218445312), // DMTC2
|
||
|
UINT64_C(1218445312), // DMTC2_OCTEON
|
||
|
UINT64_C(220), // DMUH
|
||
|
UINT64_C(221), // DMUHU
|
||
|
UINT64_C(1879048195), // DMUL
|
||
|
UINT64_C(28), // DMULT
|
||
|
UINT64_C(29), // DMULTu
|
||
|
UINT64_C(157), // DMULU
|
||
|
UINT64_C(156), // DMUL_R6
|
||
|
UINT64_C(2019557395), // DOTP_S_D
|
||
|
UINT64_C(2015363091), // DOTP_S_H
|
||
|
UINT64_C(2017460243), // DOTP_S_W
|
||
|
UINT64_C(2027946003), // DOTP_U_D
|
||
|
UINT64_C(2023751699), // DOTP_U_H
|
||
|
UINT64_C(2025848851), // DOTP_U_W
|
||
|
UINT64_C(2036334611), // DPADD_S_D
|
||
|
UINT64_C(2032140307), // DPADD_S_H
|
||
|
UINT64_C(2034237459), // DPADD_S_W
|
||
|
UINT64_C(2044723219), // DPADD_U_D
|
||
|
UINT64_C(2040528915), // DPADD_U_H
|
||
|
UINT64_C(2042626067), // DPADD_U_W
|
||
|
UINT64_C(2080376496), // DPAQX_SA_W_PH
|
||
|
UINT64_C(12988), // DPAQX_SA_W_PH_MMR2
|
||
|
UINT64_C(2080376368), // DPAQX_S_W_PH
|
||
|
UINT64_C(8892), // DPAQX_S_W_PH_MMR2
|
||
|
UINT64_C(2080375600), // DPAQ_SA_L_W
|
||
|
UINT64_C(4796), // DPAQ_SA_L_W_MM
|
||
|
UINT64_C(2080375088), // DPAQ_S_W_PH
|
||
|
UINT64_C(700), // DPAQ_S_W_PH_MM
|
||
|
UINT64_C(2080375024), // DPAU_H_QBL
|
||
|
UINT64_C(8380), // DPAU_H_QBL_MM
|
||
|
UINT64_C(2080375280), // DPAU_H_QBR
|
||
|
UINT64_C(12476), // DPAU_H_QBR_MM
|
||
|
UINT64_C(2080375344), // DPAX_W_PH
|
||
|
UINT64_C(4284), // DPAX_W_PH_MMR2
|
||
|
UINT64_C(2080374832), // DPA_W_PH
|
||
|
UINT64_C(188), // DPA_W_PH_MMR2
|
||
|
UINT64_C(1879048237), // DPOP
|
||
|
UINT64_C(2080376560), // DPSQX_SA_W_PH
|
||
|
UINT64_C(14012), // DPSQX_SA_W_PH_MMR2
|
||
|
UINT64_C(2080376432), // DPSQX_S_W_PH
|
||
|
UINT64_C(9916), // DPSQX_S_W_PH_MMR2
|
||
|
UINT64_C(2080375664), // DPSQ_SA_L_W
|
||
|
UINT64_C(5820), // DPSQ_SA_L_W_MM
|
||
|
UINT64_C(2080375152), // DPSQ_S_W_PH
|
||
|
UINT64_C(1724), // DPSQ_S_W_PH_MM
|
||
|
UINT64_C(2053111827), // DPSUB_S_D
|
||
|
UINT64_C(2048917523), // DPSUB_S_H
|
||
|
UINT64_C(2051014675), // DPSUB_S_W
|
||
|
UINT64_C(2061500435), // DPSUB_U_D
|
||
|
UINT64_C(2057306131), // DPSUB_U_H
|
||
|
UINT64_C(2059403283), // DPSUB_U_W
|
||
|
UINT64_C(2080375536), // DPSU_H_QBL
|
||
|
UINT64_C(9404), // DPSU_H_QBL_MM
|
||
|
UINT64_C(2080375792), // DPSU_H_QBR
|
||
|
UINT64_C(13500), // DPSU_H_QBR_MM
|
||
|
UINT64_C(2080375408), // DPSX_W_PH
|
||
|
UINT64_C(5308), // DPSX_W_PH_MMR2
|
||
|
UINT64_C(2080374896), // DPS_W_PH
|
||
|
UINT64_C(1212), // DPS_W_PH_MMR2
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2097210), // DROTR
|
||
|
UINT64_C(2097214), // DROTR32
|
||
|
UINT64_C(86), // DROTRV
|
||
|
UINT64_C(2080374948), // DSBH
|
||
|
UINT64_C(30), // DSDIV
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2080375140), // DSHD
|
||
|
UINT64_C(56), // DSLL
|
||
|
UINT64_C(60), // DSLL32
|
||
|
UINT64_C(60), // DSLL64_32
|
||
|
UINT64_C(20), // DSLLV
|
||
|
UINT64_C(59), // DSRA
|
||
|
UINT64_C(63), // DSRA32
|
||
|
UINT64_C(23), // DSRAV
|
||
|
UINT64_C(58), // DSRL
|
||
|
UINT64_C(62), // DSRL32
|
||
|
UINT64_C(22), // DSRLV
|
||
|
UINT64_C(46), // DSUB
|
||
|
UINT64_C(47), // DSUBu
|
||
|
UINT64_C(31), // DUDIV
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(59418), // DivRxRy16
|
||
|
UINT64_C(59419), // DivuRxRy16
|
||
|
UINT64_C(192), // EHB
|
||
|
UINT64_C(6144), // EHB_MM
|
||
|
UINT64_C(6144), // EHB_MMR6
|
||
|
UINT64_C(1096835104), // EI
|
||
|
UINT64_C(22396), // EI_MM
|
||
|
UINT64_C(22396), // EI_MMR6
|
||
|
UINT64_C(1107296280), // ERET
|
||
|
UINT64_C(1107296344), // ERETNC
|
||
|
UINT64_C(127868), // ERETNC_MMR6
|
||
|
UINT64_C(62332), // ERET_MM
|
||
|
UINT64_C(62332), // ERET_MMR6
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2080374784), // EXT
|
||
|
UINT64_C(2080374968), // EXTP
|
||
|
UINT64_C(2080375480), // EXTPDP
|
||
|
UINT64_C(2080375544), // EXTPDPV
|
||
|
UINT64_C(14524), // EXTPDPV_MM
|
||
|
UINT64_C(13948), // EXTPDP_MM
|
||
|
UINT64_C(2080375032), // EXTPV
|
||
|
UINT64_C(10428), // EXTPV_MM
|
||
|
UINT64_C(9852), // EXTP_MM
|
||
|
UINT64_C(2080375288), // EXTRV_RS_W
|
||
|
UINT64_C(11964), // EXTRV_RS_W_MM
|
||
|
UINT64_C(2080375160), // EXTRV_R_W
|
||
|
UINT64_C(7868), // EXTRV_R_W_MM
|
||
|
UINT64_C(2080375800), // EXTRV_S_H
|
||
|
UINT64_C(16060), // EXTRV_S_H_MM
|
||
|
UINT64_C(2080374904), // EXTRV_W
|
||
|
UINT64_C(3772), // EXTRV_W_MM
|
||
|
UINT64_C(2080375224), // EXTR_RS_W
|
||
|
UINT64_C(11900), // EXTR_RS_W_MM
|
||
|
UINT64_C(2080375096), // EXTR_R_W
|
||
|
UINT64_C(7804), // EXTR_R_W_MM
|
||
|
UINT64_C(2080375736), // EXTR_S_H
|
||
|
UINT64_C(15996), // EXTR_S_H_MM
|
||
|
UINT64_C(2080374840), // EXTR_W
|
||
|
UINT64_C(3708), // EXTR_W_MM
|
||
|
UINT64_C(1879048250), // EXTS
|
||
|
UINT64_C(1879048251), // EXTS32
|
||
|
UINT64_C(44), // EXT_MM
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(1176502277), // FABS_D32
|
||
|
UINT64_C(1176502277), // FABS_D64
|
||
|
UINT64_C(1409295227), // FABS_MM
|
||
|
UINT64_C(1174405125), // FABS_S
|
||
|
UINT64_C(1409287035), // FABS_S_MM
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2015363099), // FADD_D
|
||
|
UINT64_C(1176502272), // FADD_D32
|
||
|
UINT64_C(1176502272), // FADD_D64
|
||
|
UINT64_C(1409286448), // FADD_D_MMR6
|
||
|
UINT64_C(1409286448), // FADD_MM
|
||
|
UINT64_C(1174405120), // FADD_S
|
||
|
UINT64_C(1409286192), // FADD_S_MM
|
||
|
UINT64_C(1409286192), // FADD_S_MMR6
|
||
|
UINT64_C(2013265947), // FADD_W
|
||
|
UINT64_C(2015363098), // FCAF_D
|
||
|
UINT64_C(2013265946), // FCAF_W
|
||
|
UINT64_C(2023751706), // FCEQ_D
|
||
|
UINT64_C(2021654554), // FCEQ_W
|
||
|
UINT64_C(2065760286), // FCLASS_D
|
||
|
UINT64_C(2065694750), // FCLASS_W
|
||
|
UINT64_C(2040528922), // FCLE_D
|
||
|
UINT64_C(2038431770), // FCLE_W
|
||
|
UINT64_C(2032140314), // FCLT_D
|
||
|
UINT64_C(2030043162), // FCLT_W
|
||
|
UINT64_C(1176502320), // FCMP_D32
|
||
|
UINT64_C(1409287228), // FCMP_D32_MM
|
||
|
UINT64_C(1176502320), // FCMP_D64
|
||
|
UINT64_C(1174405168), // FCMP_S32
|
||
|
UINT64_C(1409286204), // FCMP_S32_MM
|
||
|
UINT64_C(2027946012), // FCNE_D
|
||
|
UINT64_C(2025848860), // FCNE_W
|
||
|
UINT64_C(2019557404), // FCOR_D
|
||
|
UINT64_C(2017460252), // FCOR_W
|
||
|
UINT64_C(2027946010), // FCUEQ_D
|
||
|
UINT64_C(2025848858), // FCUEQ_W
|
||
|
UINT64_C(2044723226), // FCULE_D
|
||
|
UINT64_C(2042626074), // FCULE_W
|
||
|
UINT64_C(2036334618), // FCULT_D
|
||
|
UINT64_C(2034237466), // FCULT_W
|
||
|
UINT64_C(2023751708), // FCUNE_D
|
||
|
UINT64_C(2021654556), // FCUNE_W
|
||
|
UINT64_C(2019557402), // FCUN_D
|
||
|
UINT64_C(2017460250), // FCUN_W
|
||
|
UINT64_C(2027946011), // FDIV_D
|
||
|
UINT64_C(1176502275), // FDIV_D32
|
||
|
UINT64_C(1176502275), // FDIV_D64
|
||
|
UINT64_C(1409286640), // FDIV_D_MMR6
|
||
|
UINT64_C(1409286640), // FDIV_MM
|
||
|
UINT64_C(1174405123), // FDIV_S
|
||
|
UINT64_C(1409286384), // FDIV_S_MM
|
||
|
UINT64_C(1409286384), // FDIV_S_MMR6
|
||
|
UINT64_C(2025848859), // FDIV_W
|
||
|
UINT64_C(2046820379), // FEXDO_H
|
||
|
UINT64_C(2048917531), // FEXDO_W
|
||
|
UINT64_C(2044723227), // FEXP2_D
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2042626075), // FEXP2_W
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2066808862), // FEXUPL_D
|
||
|
UINT64_C(2066743326), // FEXUPL_W
|
||
|
UINT64_C(2066939934), // FEXUPR_D
|
||
|
UINT64_C(2066874398), // FEXUPR_W
|
||
|
UINT64_C(2067595294), // FFINT_S_D
|
||
|
UINT64_C(2067529758), // FFINT_S_W
|
||
|
UINT64_C(2067726366), // FFINT_U_D
|
||
|
UINT64_C(2067660830), // FFINT_U_W
|
||
|
UINT64_C(2067071006), // FFQL_D
|
||
|
UINT64_C(2067005470), // FFQL_W
|
||
|
UINT64_C(2067202078), // FFQR_D
|
||
|
UINT64_C(2067136542), // FFQR_W
|
||
|
UINT64_C(2063597598), // FILL_B
|
||
|
UINT64_C(2063794206), // FILL_D
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2063663134), // FILL_H
|
||
|
UINT64_C(2063728670), // FILL_W
|
||
|
UINT64_C(2066677790), // FLOG2_D
|
||
|
UINT64_C(2066612254), // FLOG2_W
|
||
|
UINT64_C(1176502283), // FLOOR_L_D64
|
||
|
UINT64_C(1409303355), // FLOOR_L_D_MMR6
|
||
|
UINT64_C(1174405131), // FLOOR_L_S
|
||
|
UINT64_C(1409286971), // FLOOR_L_S_MMR6
|
||
|
UINT64_C(1176502287), // FLOOR_W_D32
|
||
|
UINT64_C(1176502287), // FLOOR_W_D64
|
||
|
UINT64_C(1409305403), // FLOOR_W_D_MMR6
|
||
|
UINT64_C(1409305403), // FLOOR_W_MM
|
||
|
UINT64_C(1174405135), // FLOOR_W_S
|
||
|
UINT64_C(1409289019), // FLOOR_W_S_MM
|
||
|
UINT64_C(1409289019), // FLOOR_W_S_MMR6
|
||
|
UINT64_C(2032140315), // FMADD_D
|
||
|
UINT64_C(2030043163), // FMADD_W
|
||
|
UINT64_C(2078277659), // FMAX_A_D
|
||
|
UINT64_C(2076180507), // FMAX_A_W
|
||
|
UINT64_C(2074083355), // FMAX_D
|
||
|
UINT64_C(2071986203), // FMAX_W
|
||
|
UINT64_C(2069889051), // FMIN_A_D
|
||
|
UINT64_C(2067791899), // FMIN_A_W
|
||
|
UINT64_C(2065694747), // FMIN_D
|
||
|
UINT64_C(2063597595), // FMIN_W
|
||
|
UINT64_C(1176502278), // FMOV_D32
|
||
|
UINT64_C(1409294459), // FMOV_D32_MM
|
||
|
UINT64_C(1176502278), // FMOV_D64
|
||
|
UINT64_C(1409294459), // FMOV_D_MMR6
|
||
|
UINT64_C(1174405126), // FMOV_S
|
||
|
UINT64_C(1409286267), // FMOV_S_MM
|
||
|
UINT64_C(1409286267), // FMOV_S_MMR6
|
||
|
UINT64_C(2036334619), // FMSUB_D
|
||
|
UINT64_C(2034237467), // FMSUB_W
|
||
|
UINT64_C(2023751707), // FMUL_D
|
||
|
UINT64_C(1176502274), // FMUL_D32
|
||
|
UINT64_C(1176502274), // FMUL_D64
|
||
|
UINT64_C(1409286576), // FMUL_D_MMR6
|
||
|
UINT64_C(1409286576), // FMUL_MM
|
||
|
UINT64_C(1174405122), // FMUL_S
|
||
|
UINT64_C(1409286320), // FMUL_S_MM
|
||
|
UINT64_C(1409286320), // FMUL_S_MMR6
|
||
|
UINT64_C(2021654555), // FMUL_W
|
||
|
UINT64_C(1176502279), // FNEG_D32
|
||
|
UINT64_C(1176502279), // FNEG_D64
|
||
|
UINT64_C(1409297275), // FNEG_D_MMR6
|
||
|
UINT64_C(1409297275), // FNEG_MM
|
||
|
UINT64_C(1174405127), // FNEG_S
|
||
|
UINT64_C(1409289083), // FNEG_S_MM
|
||
|
UINT64_C(1409289083), // FNEG_S_MMR6
|
||
|
UINT64_C(2066415646), // FRCP_D
|
||
|
UINT64_C(2066350110), // FRCP_W
|
||
|
UINT64_C(2066546718), // FRINT_D
|
||
|
UINT64_C(2066481182), // FRINT_W
|
||
|
UINT64_C(2066284574), // FRSQRT_D
|
||
|
UINT64_C(2066219038), // FRSQRT_W
|
||
|
UINT64_C(2048917530), // FSAF_D
|
||
|
UINT64_C(2046820378), // FSAF_W
|
||
|
UINT64_C(2057306138), // FSEQ_D
|
||
|
UINT64_C(2055208986), // FSEQ_W
|
||
|
UINT64_C(2074083354), // FSLE_D
|
||
|
UINT64_C(2071986202), // FSLE_W
|
||
|
UINT64_C(2065694746), // FSLT_D
|
||
|
UINT64_C(2063597594), // FSLT_W
|
||
|
UINT64_C(2061500444), // FSNE_D
|
||
|
UINT64_C(2059403292), // FSNE_W
|
||
|
UINT64_C(2053111836), // FSOR_D
|
||
|
UINT64_C(2051014684), // FSOR_W
|
||
|
UINT64_C(2066153502), // FSQRT_D
|
||
|
UINT64_C(1176502276), // FSQRT_D32
|
||
|
UINT64_C(1176502276), // FSQRT_D64
|
||
|
UINT64_C(1409305147), // FSQRT_MM
|
||
|
UINT64_C(1174405124), // FSQRT_S
|
||
|
UINT64_C(1409288763), // FSQRT_S_MM
|
||
|
UINT64_C(2066087966), // FSQRT_W
|
||
|
UINT64_C(2019557403), // FSUB_D
|
||
|
UINT64_C(1176502273), // FSUB_D32
|
||
|
UINT64_C(1176502273), // FSUB_D64
|
||
|
UINT64_C(1409286512), // FSUB_D_MMR6
|
||
|
UINT64_C(1409286512), // FSUB_MM
|
||
|
UINT64_C(1174405121), // FSUB_S
|
||
|
UINT64_C(1409286256), // FSUB_S_MM
|
||
|
UINT64_C(1409286256), // FSUB_S_MMR6
|
||
|
UINT64_C(2017460251), // FSUB_W
|
||
|
UINT64_C(2061500442), // FSUEQ_D
|
||
|
UINT64_C(2059403290), // FSUEQ_W
|
||
|
UINT64_C(2078277658), // FSULE_D
|
||
|
UINT64_C(2076180506), // FSULE_W
|
||
|
UINT64_C(2069889050), // FSULT_D
|
||
|
UINT64_C(2067791898), // FSULT_W
|
||
|
UINT64_C(2057306140), // FSUNE_D
|
||
|
UINT64_C(2055208988), // FSUNE_W
|
||
|
UINT64_C(2053111834), // FSUN_D
|
||
|
UINT64_C(2051014682), // FSUN_W
|
||
|
UINT64_C(2067333150), // FTINT_S_D
|
||
|
UINT64_C(2067267614), // FTINT_S_W
|
||
|
UINT64_C(2067464222), // FTINT_U_D
|
||
|
UINT64_C(2067398686), // FTINT_U_W
|
||
|
UINT64_C(2055208987), // FTQ_H
|
||
|
UINT64_C(2057306139), // FTQ_W
|
||
|
UINT64_C(2065891358), // FTRUNC_S_D
|
||
|
UINT64_C(2065825822), // FTRUNC_S_W
|
||
|
UINT64_C(2066022430), // FTRUNC_U_D
|
||
|
UINT64_C(2065956894), // FTRUNC_U_W
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2053111829), // HADD_S_D
|
||
|
UINT64_C(2048917525), // HADD_S_H
|
||
|
UINT64_C(2051014677), // HADD_S_W
|
||
|
UINT64_C(2061500437), // HADD_U_D
|
||
|
UINT64_C(2057306133), // HADD_U_H
|
||
|
UINT64_C(2059403285), // HADD_U_W
|
||
|
UINT64_C(2069889045), // HSUB_S_D
|
||
|
UINT64_C(2065694741), // HSUB_S_H
|
||
|
UINT64_C(2067791893), // HSUB_S_W
|
||
|
UINT64_C(2078277653), // HSUB_U_D
|
||
|
UINT64_C(2074083349), // HSUB_U_H
|
||
|
UINT64_C(2076180501), // HSUB_U_W
|
||
|
UINT64_C(2063597588), // ILVEV_B
|
||
|
UINT64_C(2069889044), // ILVEV_D
|
||
|
UINT64_C(2065694740), // ILVEV_H
|
||
|
UINT64_C(2067791892), // ILVEV_W
|
||
|
UINT64_C(2046820372), // ILVL_B
|
||
|
UINT64_C(2053111828), // ILVL_D
|
||
|
UINT64_C(2048917524), // ILVL_H
|
||
|
UINT64_C(2051014676), // ILVL_W
|
||
|
UINT64_C(2071986196), // ILVOD_B
|
||
|
UINT64_C(2078277652), // ILVOD_D
|
||
|
UINT64_C(2074083348), // ILVOD_H
|
||
|
UINT64_C(2076180500), // ILVOD_W
|
||
|
UINT64_C(2055208980), // ILVR_B
|
||
|
UINT64_C(2061500436), // ILVR_D
|
||
|
UINT64_C(2057306132), // ILVR_H
|
||
|
UINT64_C(2059403284), // ILVR_W
|
||
|
UINT64_C(2080374788), // INS
|
||
|
UINT64_C(2030043161), // INSERT_B
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2033713177), // INSERT_D
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2032140313), // INSERT_H
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2033188889), // INSERT_W
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2080374796), // INSV
|
||
|
UINT64_C(2034237465), // INSVE_B
|
||
|
UINT64_C(2037907481), // INSVE_D
|
||
|
UINT64_C(2036334617), // INSVE_H
|
||
|
UINT64_C(2037383193), // INSVE_W
|
||
|
UINT64_C(16700), // INSV_MM
|
||
|
UINT64_C(12), // INS_MM
|
||
|
UINT64_C(134217728), // J
|
||
|
UINT64_C(201326592), // JAL
|
||
|
UINT64_C(9), // JALR
|
||
|
UINT64_C(17856), // JALR16_MM
|
||
|
UINT64_C(9), // JALR64
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(17419), // JALRC16_MMR6
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(17888), // JALRS16_MM
|
||
|
UINT64_C(20284), // JALRS_MM
|
||
|
UINT64_C(1033), // JALR_HB
|
||
|
UINT64_C(3900), // JALR_MM
|
||
|
UINT64_C(1946157056), // JALS_MM
|
||
|
UINT64_C(1946157056), // JALX
|
||
|
UINT64_C(4026531840), // JALX_MM
|
||
|
UINT64_C(4093640704), // JAL_MM
|
||
|
UINT64_C(4160749568), // JIALC
|
||
|
UINT64_C(2147483648), // JIALC_MMR6
|
||
|
UINT64_C(3623878656), // JIC
|
||
|
UINT64_C(2684354560), // JIC_MMR6
|
||
|
UINT64_C(8), // JR
|
||
|
UINT64_C(17792), // JR16_MM
|
||
|
UINT64_C(8), // JR64
|
||
|
UINT64_C(18176), // JRADDIUSP
|
||
|
UINT64_C(17824), // JRC16_MM
|
||
|
UINT64_C(17411), // JRC16_MMR6
|
||
|
UINT64_C(17427), // JRCADDIUSP_MMR6
|
||
|
UINT64_C(1032), // JR_HB
|
||
|
UINT64_C(1033), // JR_HB_R6
|
||
|
UINT64_C(3900), // JR_MM
|
||
|
UINT64_C(3556769792), // J_MM
|
||
|
UINT64_C(402653184), // Jal16
|
||
|
UINT64_C(402653184), // JalB16
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(59424), // JrRa16
|
||
|
UINT64_C(59616), // JrcRa16
|
||
|
UINT64_C(59584), // JrcRx16
|
||
|
UINT64_C(59392), // JumpLinkReg16
|
||
|
UINT64_C(2147483648), // LB
|
||
|
UINT64_C(2147483648), // LB64
|
||
|
UINT64_C(2080374828), // LBE
|
||
|
UINT64_C(1610639360), // LBE_MM
|
||
|
UINT64_C(1610639360), // LBE_MMR6
|
||
|
UINT64_C(2048), // LBU16_MM
|
||
|
UINT64_C(1610637312), // LBUE_MMR6
|
||
|
UINT64_C(2080375178), // LBUX
|
||
|
UINT64_C(549), // LBUX_MM
|
||
|
UINT64_C(335544320), // LBU_MMR6
|
||
|
UINT64_C(469762048), // LB_MM
|
||
|
UINT64_C(469762048), // LB_MMR6
|
||
|
UINT64_C(2415919104), // LBu
|
||
|
UINT64_C(2415919104), // LBu64
|
||
|
UINT64_C(2080374824), // LBuE
|
||
|
UINT64_C(1610637312), // LBuE_MM
|
||
|
UINT64_C(335544320), // LBu_MM
|
||
|
UINT64_C(3690987520), // LD
|
||
|
UINT64_C(3556769792), // LDC1
|
||
|
UINT64_C(3556769792), // LDC164
|
||
|
UINT64_C(3154116608), // LDC1_MM
|
||
|
UINT64_C(3623878656), // LDC2
|
||
|
UINT64_C(1237319680), // LDC2_R6
|
||
|
UINT64_C(3690987520), // LDC3
|
||
|
UINT64_C(2063597575), // LDI_B
|
||
|
UINT64_C(2069889031), // LDI_D
|
||
|
UINT64_C(2065694727), // LDI_H
|
||
|
UINT64_C(2067791879), // LDI_W
|
||
|
UINT64_C(1744830464), // LDL
|
||
|
UINT64_C(3960995840), // LDPC
|
||
|
UINT64_C(1811939328), // LDR
|
||
|
UINT64_C(1275068417), // LDXC1
|
||
|
UINT64_C(1275068417), // LDXC164
|
||
|
UINT64_C(2013265952), // LD_B
|
||
|
UINT64_C(2013265955), // LD_D
|
||
|
UINT64_C(2013265953), // LD_H
|
||
|
UINT64_C(2013265954), // LD_W
|
||
|
UINT64_C(603979776), // LEA_ADDiu
|
||
|
UINT64_C(1677721600), // LEA_ADDiu64
|
||
|
UINT64_C(805306368), // LEA_ADDiu_MM
|
||
|
UINT64_C(2214592512), // LH
|
||
|
UINT64_C(2214592512), // LH64
|
||
|
UINT64_C(2080374829), // LHE
|
||
|
UINT64_C(1610639872), // LHE_MM
|
||
|
UINT64_C(10240), // LHU16_MM
|
||
|
UINT64_C(2080375050), // LHX
|
||
|
UINT64_C(357), // LHX_MM
|
||
|
UINT64_C(1006632960), // LH_MM
|
||
|
UINT64_C(2483027968), // LHu
|
||
|
UINT64_C(2483027968), // LHu64
|
||
|
UINT64_C(2080374825), // LHuE
|
||
|
UINT64_C(1610637824), // LHuE_MM
|
||
|
UINT64_C(872415232), // LHu_MM
|
||
|
UINT64_C(60416), // LI16_MM
|
||
|
UINT64_C(60416), // LI16_MMR6
|
||
|
UINT64_C(3221225472), // LL
|
||
|
UINT64_C(3489660928), // LLD
|
||
|
UINT64_C(2080374839), // LLD_R6
|
||
|
UINT64_C(2080374830), // LLE
|
||
|
UINT64_C(1610640384), // LLE_MM
|
||
|
UINT64_C(1610640384), // LLE_MMR6
|
||
|
UINT64_C(1610625024), // LL_MM
|
||
|
UINT64_C(2080374838), // LL_R6
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(5), // LSA
|
||
|
UINT64_C(15), // LSA_MMR6
|
||
|
UINT64_C(5), // LSA_R6
|
||
|
UINT64_C(268435456), // LUI_MMR6
|
||
|
UINT64_C(1275068421), // LUXC1
|
||
|
UINT64_C(1275068421), // LUXC164
|
||
|
UINT64_C(1409286472), // LUXC1_MM
|
||
|
UINT64_C(1006632960), // LUi
|
||
|
UINT64_C(1006632960), // LUi64
|
||
|
UINT64_C(1101004800), // LUi_MM
|
||
|
UINT64_C(2348810240), // LW
|
||
|
UINT64_C(26624), // LW16_MM
|
||
|
UINT64_C(2348810240), // LW64
|
||
|
UINT64_C(3288334336), // LWC1
|
||
|
UINT64_C(2617245696), // LWC1_MM
|
||
|
UINT64_C(3355443200), // LWC2
|
||
|
UINT64_C(1228931072), // LWC2_R6
|
||
|
UINT64_C(3422552064), // LWC3
|
||
|
UINT64_C(2080374831), // LWE
|
||
|
UINT64_C(1610640896), // LWE_MM
|
||
|
UINT64_C(1610640896), // LWE_MMR6
|
||
|
UINT64_C(25600), // LWGP_MM
|
||
|
UINT64_C(2281701376), // LWL
|
||
|
UINT64_C(2281701376), // LWL64
|
||
|
UINT64_C(2080374809), // LWLE
|
||
|
UINT64_C(1610638336), // LWLE_MM
|
||
|
UINT64_C(1610612736), // LWL_MM
|
||
|
UINT64_C(17664), // LWM16_MM
|
||
|
UINT64_C(17410), // LWM16_MMR6
|
||
|
UINT64_C(536891392), // LWM32_MM
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(3959947264), // LWPC
|
||
|
UINT64_C(2013790208), // LWPC_MMR6
|
||
|
UINT64_C(536875008), // LWP_MM
|
||
|
UINT64_C(2550136832), // LWR
|
||
|
UINT64_C(2550136832), // LWR64
|
||
|
UINT64_C(2080374810), // LWRE
|
||
|
UINT64_C(1610638848), // LWRE_MM
|
||
|
UINT64_C(1610616832), // LWR_MM
|
||
|
UINT64_C(18432), // LWSP_MM
|
||
|
UINT64_C(3960471552), // LWUPC
|
||
|
UINT64_C(1610670080), // LWU_MM
|
||
|
UINT64_C(2080374794), // LWX
|
||
|
UINT64_C(1275068416), // LWXC1
|
||
|
UINT64_C(1409286216), // LWXC1_MM
|
||
|
UINT64_C(280), // LWXS_MM
|
||
|
UINT64_C(421), // LWX_MM
|
||
|
UINT64_C(4227858432), // LW_MM
|
||
|
UINT64_C(4227858432), // LW_MMR6
|
||
|
UINT64_C(2617245696), // LWu
|
||
|
UINT64_C(4026570752), // LbRxRyOffMemX16
|
||
|
UINT64_C(4026572800), // LbuRxRyOffMemX16
|
||
|
UINT64_C(4026572800), // LhRxRyOffMemX16
|
||
|
UINT64_C(4026572800), // LhuRxRyOffMemX16
|
||
|
UINT64_C(26624), // LiRxImm16
|
||
|
UINT64_C(4026558464), // LiRxImmAlignX16
|
||
|
UINT64_C(4026558464), // LiRxImmX16
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(45056), // LwRxPcTcp16
|
||
|
UINT64_C(4026576896), // LwRxPcTcpX16
|
||
|
UINT64_C(4026570752), // LwRxRyOffMemX16
|
||
|
UINT64_C(4026568704), // LwRxSpImmX16
|
||
|
UINT64_C(1879048192), // MADD
|
||
|
UINT64_C(1176502296), // MADDF_D
|
||
|
UINT64_C(1409287096), // MADDF_D_MMR6
|
||
|
UINT64_C(1174405144), // MADDF_S
|
||
|
UINT64_C(1409286584), // MADDF_S_MMR6
|
||
|
UINT64_C(2067791900), // MADDR_Q_H
|
||
|
UINT64_C(2069889052), // MADDR_Q_W
|
||
|
UINT64_C(1879048193), // MADDU
|
||
|
UINT64_C(1879048193), // MADDU_DSP
|
||
|
UINT64_C(6844), // MADDU_DSP_MM
|
||
|
UINT64_C(56124), // MADDU_MM
|
||
|
UINT64_C(2021654546), // MADDV_B
|
||
|
UINT64_C(2027946002), // MADDV_D
|
||
|
UINT64_C(2023751698), // MADDV_H
|
||
|
UINT64_C(2025848850), // MADDV_W
|
||
|
UINT64_C(1275068449), // MADD_D32
|
||
|
UINT64_C(1409286153), // MADD_D32_MM
|
||
|
UINT64_C(1275068449), // MADD_D64
|
||
|
UINT64_C(1879048192), // MADD_DSP
|
||
|
UINT64_C(2748), // MADD_DSP_MM
|
||
|
UINT64_C(52028), // MADD_MM
|
||
|
UINT64_C(2034237468), // MADD_Q_H
|
||
|
UINT64_C(2036334620), // MADD_Q_W
|
||
|
UINT64_C(1275068448), // MADD_S
|
||
|
UINT64_C(1409286145), // MADD_S_MM
|
||
|
UINT64_C(2080375856), // MAQ_SA_W_PHL
|
||
|
UINT64_C(14972), // MAQ_SA_W_PHL_MM
|
||
|
UINT64_C(2080375984), // MAQ_SA_W_PHR
|
||
|
UINT64_C(10876), // MAQ_SA_W_PHR_MM
|
||
|
UINT64_C(2080376112), // MAQ_S_W_PHL
|
||
|
UINT64_C(6780), // MAQ_S_W_PHL_MM
|
||
|
UINT64_C(2080376240), // MAQ_S_W_PHR
|
||
|
UINT64_C(2684), // MAQ_S_W_PHR_MM
|
||
|
UINT64_C(1176502303), // MAXA_D
|
||
|
UINT64_C(1409286699), // MAXA_D_MMR6
|
||
|
UINT64_C(1174405151), // MAXA_S
|
||
|
UINT64_C(1409286187), // MAXA_S_MMR6
|
||
|
UINT64_C(2030043142), // MAXI_S_B
|
||
|
UINT64_C(2036334598), // MAXI_S_D
|
||
|
UINT64_C(2032140294), // MAXI_S_H
|
||
|
UINT64_C(2034237446), // MAXI_S_W
|
||
|
UINT64_C(2038431750), // MAXI_U_B
|
||
|
UINT64_C(2044723206), // MAXI_U_D
|
||
|
UINT64_C(2040528902), // MAXI_U_H
|
||
|
UINT64_C(2042626054), // MAXI_U_W
|
||
|
UINT64_C(2063597582), // MAX_A_B
|
||
|
UINT64_C(2069889038), // MAX_A_D
|
||
|
UINT64_C(2065694734), // MAX_A_H
|
||
|
UINT64_C(2067791886), // MAX_A_W
|
||
|
UINT64_C(1176502301), // MAX_D
|
||
|
UINT64_C(1409286667), // MAX_D_MMR6
|
||
|
UINT64_C(1174405149), // MAX_S
|
||
|
UINT64_C(2030043150), // MAX_S_B
|
||
|
UINT64_C(2036334606), // MAX_S_D
|
||
|
UINT64_C(2032140302), // MAX_S_H
|
||
|
UINT64_C(1409286155), // MAX_S_MMR6
|
||
|
UINT64_C(2034237454), // MAX_S_W
|
||
|
UINT64_C(2038431758), // MAX_U_B
|
||
|
UINT64_C(2044723214), // MAX_U_D
|
||
|
UINT64_C(2040528910), // MAX_U_H
|
||
|
UINT64_C(2042626062), // MAX_U_W
|
||
|
UINT64_C(1073741824), // MFC0
|
||
|
UINT64_C(1140850688), // MFC1
|
||
|
UINT64_C(1409294395), // MFC1_MM
|
||
|
UINT64_C(1207959552), // MFC2
|
||
|
UINT64_C(1147142144), // MFHC1_D32
|
||
|
UINT64_C(1147142144), // MFHC1_D64
|
||
|
UINT64_C(1409298491), // MFHC1_MM
|
||
|
UINT64_C(16), // MFHI
|
||
|
UINT64_C(17920), // MFHI16_MM
|
||
|
UINT64_C(16), // MFHI64
|
||
|
UINT64_C(16), // MFHI_DSP
|
||
|
UINT64_C(124), // MFHI_DSP_MM
|
||
|
UINT64_C(3452), // MFHI_MM
|
||
|
UINT64_C(18), // MFLO
|
||
|
UINT64_C(17984), // MFLO16_MM
|
||
|
UINT64_C(18), // MFLO64
|
||
|
UINT64_C(18), // MFLO_DSP
|
||
|
UINT64_C(4220), // MFLO_DSP_MM
|
||
|
UINT64_C(7548), // MFLO_MM
|
||
|
UINT64_C(1176502302), // MINA_D
|
||
|
UINT64_C(1409286691), // MINA_D_MMR6
|
||
|
UINT64_C(1174405150), // MINA_S
|
||
|
UINT64_C(1409286179), // MINA_S_MMR6
|
||
|
UINT64_C(2046820358), // MINI_S_B
|
||
|
UINT64_C(2053111814), // MINI_S_D
|
||
|
UINT64_C(2048917510), // MINI_S_H
|
||
|
UINT64_C(2051014662), // MINI_S_W
|
||
|
UINT64_C(2055208966), // MINI_U_B
|
||
|
UINT64_C(2061500422), // MINI_U_D
|
||
|
UINT64_C(2057306118), // MINI_U_H
|
||
|
UINT64_C(2059403270), // MINI_U_W
|
||
|
UINT64_C(2071986190), // MIN_A_B
|
||
|
UINT64_C(2078277646), // MIN_A_D
|
||
|
UINT64_C(2074083342), // MIN_A_H
|
||
|
UINT64_C(2076180494), // MIN_A_W
|
||
|
UINT64_C(1176502300), // MIN_D
|
||
|
UINT64_C(1409286659), // MIN_D_MMR6
|
||
|
UINT64_C(1174405148), // MIN_S
|
||
|
UINT64_C(2046820366), // MIN_S_B
|
||
|
UINT64_C(2053111822), // MIN_S_D
|
||
|
UINT64_C(2048917518), // MIN_S_H
|
||
|
UINT64_C(1409286147), // MIN_S_MMR6
|
||
|
UINT64_C(2051014670), // MIN_S_W
|
||
|
UINT64_C(2055208974), // MIN_U_B
|
||
|
UINT64_C(2061500430), // MIN_U_D
|
||
|
UINT64_C(2057306126), // MIN_U_H
|
||
|
UINT64_C(2059403278), // MIN_U_W
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(218), // MOD
|
||
|
UINT64_C(2080375952), // MODSUB
|
||
|
UINT64_C(219), // MODU
|
||
|
UINT64_C(472), // MODU_MMR6
|
||
|
UINT64_C(344), // MOD_MMR6
|
||
|
UINT64_C(2063597586), // MOD_S_B
|
||
|
UINT64_C(2069889042), // MOD_S_D
|
||
|
UINT64_C(2065694738), // MOD_S_H
|
||
|
UINT64_C(2067791890), // MOD_S_W
|
||
|
UINT64_C(2071986194), // MOD_U_B
|
||
|
UINT64_C(2078277650), // MOD_U_D
|
||
|
UINT64_C(2074083346), // MOD_U_H
|
||
|
UINT64_C(2076180498), // MOD_U_W
|
||
|
UINT64_C(3072), // MOVE16_MM
|
||
|
UINT64_C(3072), // MOVE16_MMR6
|
||
|
UINT64_C(33792), // MOVEP_MM
|
||
|
UINT64_C(2025717785), // MOVE_V
|
||
|
UINT64_C(1176502289), // MOVF_D32
|
||
|
UINT64_C(1409286688), // MOVF_D32_MM
|
||
|
UINT64_C(1176502289), // MOVF_D64
|
||
|
UINT64_C(1), // MOVF_I
|
||
|
UINT64_C(1), // MOVF_I64
|
||
|
UINT64_C(1409286523), // MOVF_I_MM
|
||
|
UINT64_C(1174405137), // MOVF_S
|
||
|
UINT64_C(1409286176), // MOVF_S_MM
|
||
|
UINT64_C(1176502291), // MOVN_I64_D64
|
||
|
UINT64_C(11), // MOVN_I64_I
|
||
|
UINT64_C(11), // MOVN_I64_I64
|
||
|
UINT64_C(1174405139), // MOVN_I64_S
|
||
|
UINT64_C(1176502291), // MOVN_I_D32
|
||
|
UINT64_C(1409286456), // MOVN_I_D32_MM
|
||
|
UINT64_C(1176502291), // MOVN_I_D64
|
||
|
UINT64_C(11), // MOVN_I_I
|
||
|
UINT64_C(11), // MOVN_I_I64
|
||
|
UINT64_C(24), // MOVN_I_MM
|
||
|
UINT64_C(1174405139), // MOVN_I_S
|
||
|
UINT64_C(1409286200), // MOVN_I_S_MM
|
||
|
UINT64_C(1176567825), // MOVT_D32
|
||
|
UINT64_C(1409286752), // MOVT_D32_MM
|
||
|
UINT64_C(1176567825), // MOVT_D64
|
||
|
UINT64_C(65537), // MOVT_I
|
||
|
UINT64_C(65537), // MOVT_I64
|
||
|
UINT64_C(1409288571), // MOVT_I_MM
|
||
|
UINT64_C(1174470673), // MOVT_S
|
||
|
UINT64_C(1409286240), // MOVT_S_MM
|
||
|
UINT64_C(1176502290), // MOVZ_I64_D64
|
||
|
UINT64_C(10), // MOVZ_I64_I
|
||
|
UINT64_C(10), // MOVZ_I64_I64
|
||
|
UINT64_C(1174405138), // MOVZ_I64_S
|
||
|
UINT64_C(1176502290), // MOVZ_I_D32
|
||
|
UINT64_C(1409286520), // MOVZ_I_D32_MM
|
||
|
UINT64_C(1176502290), // MOVZ_I_D64
|
||
|
UINT64_C(10), // MOVZ_I_I
|
||
|
UINT64_C(10), // MOVZ_I_I64
|
||
|
UINT64_C(88), // MOVZ_I_MM
|
||
|
UINT64_C(1174405138), // MOVZ_I_S
|
||
|
UINT64_C(1409286264), // MOVZ_I_S_MM
|
||
|
UINT64_C(1879048196), // MSUB
|
||
|
UINT64_C(1176502297), // MSUBF_D
|
||
|
UINT64_C(1409287160), // MSUBF_D_MMR6
|
||
|
UINT64_C(1174405145), // MSUBF_S
|
||
|
UINT64_C(1409286648), // MSUBF_S_MMR6
|
||
|
UINT64_C(2071986204), // MSUBR_Q_H
|
||
|
UINT64_C(2074083356), // MSUBR_Q_W
|
||
|
UINT64_C(1879048197), // MSUBU
|
||
|
UINT64_C(1879048197), // MSUBU_DSP
|
||
|
UINT64_C(15036), // MSUBU_DSP_MM
|
||
|
UINT64_C(64316), // MSUBU_MM
|
||
|
UINT64_C(2030043154), // MSUBV_B
|
||
|
UINT64_C(2036334610), // MSUBV_D
|
||
|
UINT64_C(2032140306), // MSUBV_H
|
||
|
UINT64_C(2034237458), // MSUBV_W
|
||
|
UINT64_C(1275068457), // MSUB_D32
|
||
|
UINT64_C(1409286185), // MSUB_D32_MM
|
||
|
UINT64_C(1275068457), // MSUB_D64
|
||
|
UINT64_C(1879048196), // MSUB_DSP
|
||
|
UINT64_C(10940), // MSUB_DSP_MM
|
||
|
UINT64_C(60220), // MSUB_MM
|
||
|
UINT64_C(2038431772), // MSUB_Q_H
|
||
|
UINT64_C(2040528924), // MSUB_Q_W
|
||
|
UINT64_C(1275068456), // MSUB_S
|
||
|
UINT64_C(1409286177), // MSUB_S_MM
|
||
|
UINT64_C(1082130432), // MTC0
|
||
|
UINT64_C(1149239296), // MTC1
|
||
|
UINT64_C(1409296443), // MTC1_MM
|
||
|
UINT64_C(1216348160), // MTC2
|
||
|
UINT64_C(1155530752), // MTHC1_D32
|
||
|
UINT64_C(1155530752), // MTHC1_D64
|
||
|
UINT64_C(1409300539), // MTHC1_MM
|
||
|
UINT64_C(17), // MTHI
|
||
|
UINT64_C(17), // MTHI64
|
||
|
UINT64_C(17), // MTHI_DSP
|
||
|
UINT64_C(8316), // MTHI_DSP_MM
|
||
|
UINT64_C(11644), // MTHI_MM
|
||
|
UINT64_C(2080376824), // MTHLIP
|
||
|
UINT64_C(636), // MTHLIP_MM
|
||
|
UINT64_C(19), // MTLO
|
||
|
UINT64_C(19), // MTLO64
|
||
|
UINT64_C(19), // MTLO_DSP
|
||
|
UINT64_C(12412), // MTLO_DSP_MM
|
||
|
UINT64_C(15740), // MTLO_MM
|
||
|
UINT64_C(1879048200), // MTM0
|
||
|
UINT64_C(1879048204), // MTM1
|
||
|
UINT64_C(1879048205), // MTM2
|
||
|
UINT64_C(1879048201), // MTP0
|
||
|
UINT64_C(1879048202), // MTP1
|
||
|
UINT64_C(1879048203), // MTP2
|
||
|
UINT64_C(216), // MUH
|
||
|
UINT64_C(217), // MUHU
|
||
|
UINT64_C(216), // MUHU_MMR6
|
||
|
UINT64_C(88), // MUH_MMR6
|
||
|
UINT64_C(1879048194), // MUL
|
||
|
UINT64_C(2080376592), // MULEQ_S_W_PHL
|
||
|
UINT64_C(37), // MULEQ_S_W_PHL_MM
|
||
|
UINT64_C(2080376656), // MULEQ_S_W_PHR
|
||
|
UINT64_C(101), // MULEQ_S_W_PHR_MM
|
||
|
UINT64_C(2080375184), // MULEU_S_PH_QBL
|
||
|
UINT64_C(149), // MULEU_S_PH_QBL_MM
|
||
|
UINT64_C(2080375248), // MULEU_S_PH_QBR
|
||
|
UINT64_C(213), // MULEU_S_PH_QBR_MM
|
||
|
UINT64_C(2080376784), // MULQ_RS_PH
|
||
|
UINT64_C(277), // MULQ_RS_PH_MM
|
||
|
UINT64_C(2080376280), // MULQ_RS_W
|
||
|
UINT64_C(405), // MULQ_RS_W_MMR2
|
||
|
UINT64_C(2080376720), // MULQ_S_PH
|
||
|
UINT64_C(341), // MULQ_S_PH_MMR2
|
||
|
UINT64_C(2080376216), // MULQ_S_W
|
||
|
UINT64_C(469), // MULQ_S_W_MMR2
|
||
|
UINT64_C(2063597596), // MULR_Q_H
|
||
|
UINT64_C(2065694748), // MULR_Q_W
|
||
|
UINT64_C(2080375216), // MULSAQ_S_W_PH
|
||
|
UINT64_C(2080374960), // MULSA_W_PH
|
||
|
UINT64_C(24), // MULT
|
||
|
UINT64_C(25), // MULTU_DSP
|
||
|
UINT64_C(7356), // MULTU_DSP_MM
|
||
|
UINT64_C(24), // MULT_DSP
|
||
|
UINT64_C(3260), // MULT_DSP_MM
|
||
|
UINT64_C(35644), // MULT_MM
|
||
|
UINT64_C(25), // MULTu
|
||
|
UINT64_C(39740), // MULTu_MM
|
||
|
UINT64_C(153), // MULU
|
||
|
UINT64_C(152), // MULU_MMR6
|
||
|
UINT64_C(2013265938), // MULV_B
|
||
|
UINT64_C(2019557394), // MULV_D
|
||
|
UINT64_C(2015363090), // MULV_H
|
||
|
UINT64_C(2017460242), // MULV_W
|
||
|
UINT64_C(528), // MUL_MM
|
||
|
UINT64_C(24), // MUL_MMR6
|
||
|
UINT64_C(2080375576), // MUL_PH
|
||
|
UINT64_C(45), // MUL_PH_MMR2
|
||
|
UINT64_C(2030043164), // MUL_Q_H
|
||
|
UINT64_C(2032140316), // MUL_Q_W
|
||
|
UINT64_C(152), // MUL_R6
|
||
|
UINT64_C(2080375704), // MUL_S_PH
|
||
|
UINT64_C(1069), // MUL_S_PH_MMR2
|
||
|
UINT64_C(59408), // Mfhi16
|
||
|
UINT64_C(59410), // Mflo16
|
||
|
UINT64_C(25856), // Move32R16
|
||
|
UINT64_C(26368), // MoveR3216
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2064121886), // NLOC_B
|
||
|
UINT64_C(2064318494), // NLOC_D
|
||
|
UINT64_C(2064187422), // NLOC_H
|
||
|
UINT64_C(2064252958), // NLOC_W
|
||
|
UINT64_C(2064384030), // NLZC_B
|
||
|
UINT64_C(2064580638), // NLZC_D
|
||
|
UINT64_C(2064449566), // NLZC_H
|
||
|
UINT64_C(2064515102), // NLZC_W
|
||
|
UINT64_C(1275068465), // NMADD_D32
|
||
|
UINT64_C(1409286154), // NMADD_D32_MM
|
||
|
UINT64_C(1275068465), // NMADD_D64
|
||
|
UINT64_C(1275068464), // NMADD_S
|
||
|
UINT64_C(1409286146), // NMADD_S_MM
|
||
|
UINT64_C(1275068473), // NMSUB_D32
|
||
|
UINT64_C(1409286186), // NMSUB_D32_MM
|
||
|
UINT64_C(1275068473), // NMSUB_D64
|
||
|
UINT64_C(1275068472), // NMSUB_S
|
||
|
UINT64_C(1409286178), // NMSUB_S_MM
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(39), // NOR
|
||
|
UINT64_C(39), // NOR64
|
||
|
UINT64_C(2046820352), // NORI_B
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(720), // NOR_MM
|
||
|
UINT64_C(720), // NOR_MMR6
|
||
|
UINT64_C(2017460254), // NOR_V
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(17408), // NOT16_MM
|
||
|
UINT64_C(17408), // NOT16_MMR6
|
||
|
UINT64_C(59421), // NegRxRy16
|
||
|
UINT64_C(59407), // NotRxRy16
|
||
|
UINT64_C(37), // OR
|
||
|
UINT64_C(17600), // OR16_MM
|
||
|
UINT64_C(17417), // OR16_MMR6
|
||
|
UINT64_C(37), // OR64
|
||
|
UINT64_C(2030043136), // ORI_B
|
||
|
UINT64_C(1342177280), // ORI_MMR6
|
||
|
UINT64_C(656), // OR_MM
|
||
|
UINT64_C(656), // OR_MMR6
|
||
|
UINT64_C(2015363102), // OR_V
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(872415232), // ORi
|
||
|
UINT64_C(872415232), // ORi64
|
||
|
UINT64_C(1342177280), // ORi_MM
|
||
|
UINT64_C(59405), // OrRxRxRy16
|
||
|
UINT64_C(2080375697), // PACKRL_PH
|
||
|
UINT64_C(429), // PACKRL_PH_MM
|
||
|
UINT64_C(320), // PAUSE
|
||
|
UINT64_C(10240), // PAUSE_MM
|
||
|
UINT64_C(10240), // PAUSE_MMR6
|
||
|
UINT64_C(2030043156), // PCKEV_B
|
||
|
UINT64_C(2036334612), // PCKEV_D
|
||
|
UINT64_C(2032140308), // PCKEV_H
|
||
|
UINT64_C(2034237460), // PCKEV_W
|
||
|
UINT64_C(2038431764), // PCKOD_B
|
||
|
UINT64_C(2044723220), // PCKOD_D
|
||
|
UINT64_C(2040528916), // PCKOD_H
|
||
|
UINT64_C(2042626068), // PCKOD_W
|
||
|
UINT64_C(2063859742), // PCNT_B
|
||
|
UINT64_C(2064056350), // PCNT_D
|
||
|
UINT64_C(2063925278), // PCNT_H
|
||
|
UINT64_C(2063990814), // PCNT_W
|
||
|
UINT64_C(2080375505), // PICK_PH
|
||
|
UINT64_C(557), // PICK_PH_MM
|
||
|
UINT64_C(2080374993), // PICK_QB
|
||
|
UINT64_C(493), // PICK_QB_MM
|
||
|
UINT64_C(1879048236), // POP
|
||
|
UINT64_C(2080375058), // PRECEQU_PH_QBL
|
||
|
UINT64_C(2080375186), // PRECEQU_PH_QBLA
|
||
|
UINT64_C(29500), // PRECEQU_PH_QBLA_MM
|
||
|
UINT64_C(28988), // PRECEQU_PH_QBL_MM
|
||
|
UINT64_C(2080375122), // PRECEQU_PH_QBR
|
||
|
UINT64_C(2080375250), // PRECEQU_PH_QBRA
|
||
|
UINT64_C(37692), // PRECEQU_PH_QBRA_MM
|
||
|
UINT64_C(37180), // PRECEQU_PH_QBR_MM
|
||
|
UINT64_C(2080375570), // PRECEQ_W_PHL
|
||
|
UINT64_C(20796), // PRECEQ_W_PHL_MM
|
||
|
UINT64_C(2080375634), // PRECEQ_W_PHR
|
||
|
UINT64_C(24892), // PRECEQ_W_PHR_MM
|
||
|
UINT64_C(2080376594), // PRECEU_PH_QBL
|
||
|
UINT64_C(2080376722), // PRECEU_PH_QBLA
|
||
|
UINT64_C(45884), // PRECEU_PH_QBLA_MM
|
||
|
UINT64_C(45372), // PRECEU_PH_QBL_MM
|
||
|
UINT64_C(2080376658), // PRECEU_PH_QBR
|
||
|
UINT64_C(2080376786), // PRECEU_PH_QBRA
|
||
|
UINT64_C(54076), // PRECEU_PH_QBRA_MM
|
||
|
UINT64_C(53564), // PRECEU_PH_QBR_MM
|
||
|
UINT64_C(2080375761), // PRECRQU_S_QB_PH
|
||
|
UINT64_C(365), // PRECRQU_S_QB_PH_MM
|
||
|
UINT64_C(2080376081), // PRECRQ_PH_W
|
||
|
UINT64_C(237), // PRECRQ_PH_W_MM
|
||
|
UINT64_C(2080375569), // PRECRQ_QB_PH
|
||
|
UINT64_C(173), // PRECRQ_QB_PH_MM
|
||
|
UINT64_C(2080376145), // PRECRQ_RS_PH_W
|
||
|
UINT64_C(301), // PRECRQ_RS_PH_W_MM
|
||
|
UINT64_C(2080375633), // PRECR_QB_PH
|
||
|
UINT64_C(109), // PRECR_QB_PH_MMR2
|
||
|
UINT64_C(2080376721), // PRECR_SRA_PH_W
|
||
|
UINT64_C(973), // PRECR_SRA_PH_W_MMR2
|
||
|
UINT64_C(2080376785), // PRECR_SRA_R_PH_W
|
||
|
UINT64_C(1997), // PRECR_SRA_R_PH_W_MMR2
|
||
|
UINT64_C(3422552064), // PREF
|
||
|
UINT64_C(2080374819), // PREFE
|
||
|
UINT64_C(1610654720), // PREFE_MM
|
||
|
UINT64_C(1610654720), // PREFE_MMR6
|
||
|
UINT64_C(1409286560), // PREFX_MM
|
||
|
UINT64_C(1610620928), // PREF_MM
|
||
|
UINT64_C(1610620928), // PREF_MMR6
|
||
|
UINT64_C(2080374837), // PREF_R6
|
||
|
UINT64_C(2080374897), // PREPEND
|
||
|
UINT64_C(597), // PREPEND_MMR2
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2080376080), // RADDU_W_QB
|
||
|
UINT64_C(61756), // RADDU_W_QB_MM
|
||
|
UINT64_C(2080375992), // RDDSP
|
||
|
UINT64_C(1660), // RDDSP_MM
|
||
|
UINT64_C(2080374843), // RDHWR
|
||
|
UINT64_C(2080374843), // RDHWR64
|
||
|
UINT64_C(27452), // RDHWR_MM
|
||
|
UINT64_C(448), // RDHWR_MMR6
|
||
|
UINT64_C(57724), // RDPGPR_MMR6
|
||
|
UINT64_C(1409307195), // RECIP_D_MMR6
|
||
|
UINT64_C(1409290811), // RECIP_S_MMR6
|
||
|
UINT64_C(2080375506), // REPLV_PH
|
||
|
UINT64_C(828), // REPLV_PH_MM
|
||
|
UINT64_C(2080374994), // REPLV_QB
|
||
|
UINT64_C(4924), // REPLV_QB_MM
|
||
|
UINT64_C(2080375442), // REPL_PH
|
||
|
UINT64_C(61), // REPL_PH_MM
|
||
|
UINT64_C(2080374930), // REPL_QB
|
||
|
UINT64_C(1532), // REPL_QB_MM
|
||
|
UINT64_C(1176502298), // RINT_D
|
||
|
UINT64_C(1409286688), // RINT_D_MMR6
|
||
|
UINT64_C(1174405146), // RINT_S
|
||
|
UINT64_C(1409286176), // RINT_S_MMR6
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2097154), // ROTR
|
||
|
UINT64_C(70), // ROTRV
|
||
|
UINT64_C(208), // ROTRV_MM
|
||
|
UINT64_C(192), // ROTR_MM
|
||
|
UINT64_C(1176502280), // ROUND_L_D64
|
||
|
UINT64_C(1409315643), // ROUND_L_D_MMR6
|
||
|
UINT64_C(1174405128), // ROUND_L_S
|
||
|
UINT64_C(1409299259), // ROUND_L_S_MMR6
|
||
|
UINT64_C(1176502284), // ROUND_W_D32
|
||
|
UINT64_C(1176502284), // ROUND_W_D64
|
||
|
UINT64_C(1409317691), // ROUND_W_D_MMR6
|
||
|
UINT64_C(1409317691), // ROUND_W_MM
|
||
|
UINT64_C(1174405132), // ROUND_W_S
|
||
|
UINT64_C(1409301307), // ROUND_W_S_MM
|
||
|
UINT64_C(1409301307), // ROUND_W_S_MMR6
|
||
|
UINT64_C(1409303099), // RSQRT_D_MMR6
|
||
|
UINT64_C(1409286715), // RSQRT_S_MMR6
|
||
|
UINT64_C(25728), // Restore16
|
||
|
UINT64_C(25728), // RestoreX16
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2020605962), // SAT_S_B
|
||
|
UINT64_C(2013265930), // SAT_S_D
|
||
|
UINT64_C(2019557386), // SAT_S_H
|
||
|
UINT64_C(2017460234), // SAT_S_W
|
||
|
UINT64_C(2028994570), // SAT_U_B
|
||
|
UINT64_C(2021654538), // SAT_U_D
|
||
|
UINT64_C(2027945994), // SAT_U_H
|
||
|
UINT64_C(2025848842), // SAT_U_W
|
||
|
UINT64_C(2684354560), // SB
|
||
|
UINT64_C(34816), // SB16_MM
|
||
|
UINT64_C(34816), // SB16_MMR6
|
||
|
UINT64_C(2684354560), // SB64
|
||
|
UINT64_C(2080374812), // SBE
|
||
|
UINT64_C(1610655744), // SBE_MM
|
||
|
UINT64_C(1610655744), // SBE_MMR6
|
||
|
UINT64_C(402653184), // SB_MM
|
||
|
UINT64_C(402653184), // SB_MMR6
|
||
|
UINT64_C(3758096384), // SC
|
||
|
UINT64_C(4026531840), // SCD
|
||
|
UINT64_C(2080374823), // SCD_R6
|
||
|
UINT64_C(2080374814), // SCE
|
||
|
UINT64_C(1610656768), // SCE_MM
|
||
|
UINT64_C(1610656768), // SCE_MMR6
|
||
|
UINT64_C(1610657792), // SC_MM
|
||
|
UINT64_C(2080374822), // SC_R6
|
||
|
UINT64_C(4227858432), // SD
|
||
|
UINT64_C(1879048255), // SDBBP
|
||
|
UINT64_C(18112), // SDBBP16_MM
|
||
|
UINT64_C(17467), // SDBBP16_MMR6
|
||
|
UINT64_C(56188), // SDBBP_MM
|
||
|
UINT64_C(56188), // SDBBP_MMR6
|
||
|
UINT64_C(14), // SDBBP_R6
|
||
|
UINT64_C(4093640704), // SDC1
|
||
|
UINT64_C(4093640704), // SDC164
|
||
|
UINT64_C(3087007744), // SDC1_MM
|
||
|
UINT64_C(4160749568), // SDC2
|
||
|
UINT64_C(1239416832), // SDC2_R6
|
||
|
UINT64_C(4227858432), // SDC3
|
||
|
UINT64_C(26), // SDIV
|
||
|
UINT64_C(43836), // SDIV_MM
|
||
|
UINT64_C(2952790016), // SDL
|
||
|
UINT64_C(3019898880), // SDR
|
||
|
UINT64_C(1275068425), // SDXC1
|
||
|
UINT64_C(1275068425), // SDXC164
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2080375840), // SEB
|
||
|
UINT64_C(2080375840), // SEB64
|
||
|
UINT64_C(11068), // SEB_MM
|
||
|
UINT64_C(11068), // SEB_MMR6
|
||
|
UINT64_C(2080376352), // SEH
|
||
|
UINT64_C(2080376352), // SEH64
|
||
|
UINT64_C(15164), // SEH_MM
|
||
|
UINT64_C(15164), // SEH_MMR6
|
||
|
UINT64_C(1409286776), // SELENZ_D_MMR6
|
||
|
UINT64_C(1409286264), // SELENZ_S_MMR6
|
||
|
UINT64_C(53), // SELEQZ
|
||
|
UINT64_C(53), // SELEQZ64
|
||
|
UINT64_C(1176502292), // SELEQZ_D
|
||
|
UINT64_C(1409286712), // SELEQZ_D_MMR6
|
||
|
UINT64_C(320), // SELEQZ_MMR6
|
||
|
UINT64_C(1174405140), // SELEQZ_S
|
||
|
UINT64_C(1409286200), // SELEQZ_S_MMR6
|
||
|
UINT64_C(55), // SELNEZ
|
||
|
UINT64_C(55), // SELNEZ64
|
||
|
UINT64_C(1176502295), // SELNEZ_D
|
||
|
UINT64_C(384), // SELNEZ_MMR6
|
||
|
UINT64_C(1174405143), // SELNEZ_S
|
||
|
UINT64_C(1176502288), // SEL_D
|
||
|
UINT64_C(1409286840), // SEL_D_MMR6
|
||
|
UINT64_C(1174405136), // SEL_S
|
||
|
UINT64_C(1409286328), // SEL_S_MMR6
|
||
|
UINT64_C(1879048234), // SEQ
|
||
|
UINT64_C(1879048238), // SEQi
|
||
|
UINT64_C(2751463424), // SH
|
||
|
UINT64_C(43008), // SH16_MM
|
||
|
UINT64_C(43008), // SH16_MMR6
|
||
|
UINT64_C(2751463424), // SH64
|
||
|
UINT64_C(2080374813), // SHE
|
||
|
UINT64_C(1610656256), // SHE_MM
|
||
|
UINT64_C(1610656256), // SHE_MMR6
|
||
|
UINT64_C(2013265922), // SHF_B
|
||
|
UINT64_C(2030043138), // SHF_H
|
||
|
UINT64_C(2046820354), // SHF_W
|
||
|
UINT64_C(2080376504), // SHILO
|
||
|
UINT64_C(2080376568), // SHILOV
|
||
|
UINT64_C(4732), // SHILOV_MM
|
||
|
UINT64_C(29), // SHILO_MM
|
||
|
UINT64_C(2080375443), // SHLLV_PH
|
||
|
UINT64_C(14), // SHLLV_PH_MM
|
||
|
UINT64_C(2080374931), // SHLLV_QB
|
||
|
UINT64_C(917), // SHLLV_QB_MM
|
||
|
UINT64_C(2080375699), // SHLLV_S_PH
|
||
|
UINT64_C(1038), // SHLLV_S_PH_MM
|
||
|
UINT64_C(2080376211), // SHLLV_S_W
|
||
|
UINT64_C(981), // SHLLV_S_W_MM
|
||
|
UINT64_C(2080375315), // SHLL_PH
|
||
|
UINT64_C(949), // SHLL_PH_MM
|
||
|
UINT64_C(2080374803), // SHLL_QB
|
||
|
UINT64_C(2172), // SHLL_QB_MM
|
||
|
UINT64_C(2080375571), // SHLL_S_PH
|
||
|
UINT64_C(2997), // SHLL_S_PH_MM
|
||
|
UINT64_C(2080376083), // SHLL_S_W
|
||
|
UINT64_C(1013), // SHLL_S_W_MM
|
||
|
UINT64_C(2080375507), // SHRAV_PH
|
||
|
UINT64_C(397), // SHRAV_PH_MM
|
||
|
UINT64_C(2080375187), // SHRAV_QB
|
||
|
UINT64_C(461), // SHRAV_QB_MMR2
|
||
|
UINT64_C(2080375763), // SHRAV_R_PH
|
||
|
UINT64_C(1421), // SHRAV_R_PH_MM
|
||
|
UINT64_C(2080375251), // SHRAV_R_QB
|
||
|
UINT64_C(1485), // SHRAV_R_QB_MMR2
|
||
|
UINT64_C(2080376275), // SHRAV_R_W
|
||
|
UINT64_C(725), // SHRAV_R_W_MM
|
||
|
UINT64_C(2080375379), // SHRA_PH
|
||
|
UINT64_C(821), // SHRA_PH_MM
|
||
|
UINT64_C(2080375059), // SHRA_QB
|
||
|
UINT64_C(508), // SHRA_QB_MMR2
|
||
|
UINT64_C(2080375635), // SHRA_R_PH
|
||
|
UINT64_C(1845), // SHRA_R_PH_MM
|
||
|
UINT64_C(2080375123), // SHRA_R_QB
|
||
|
UINT64_C(4604), // SHRA_R_QB_MMR2
|
||
|
UINT64_C(2080376147), // SHRA_R_W
|
||
|
UINT64_C(757), // SHRA_R_W_MM
|
||
|
UINT64_C(2080376531), // SHRLV_PH
|
||
|
UINT64_C(789), // SHRLV_PH_MMR2
|
||
|
UINT64_C(2080374995), // SHRLV_QB
|
||
|
UINT64_C(853), // SHRLV_QB_MM
|
||
|
UINT64_C(2080376403), // SHRL_PH
|
||
|
UINT64_C(1020), // SHRL_PH_MMR2
|
||
|
UINT64_C(2080374867), // SHRL_QB
|
||
|
UINT64_C(6268), // SHRL_QB_MM
|
||
|
UINT64_C(939524096), // SH_MM
|
||
|
UINT64_C(939524096), // SH_MMR6
|
||
|
UINT64_C(2013265945), // SLDI_B
|
||
|
UINT64_C(2016935961), // SLDI_D
|
||
|
UINT64_C(2015363097), // SLDI_H
|
||
|
UINT64_C(2016411673), // SLDI_W
|
||
|
UINT64_C(2013265940), // SLD_B
|
||
|
UINT64_C(2019557396), // SLD_D
|
||
|
UINT64_C(2015363092), // SLD_H
|
||
|
UINT64_C(2017460244), // SLD_W
|
||
|
UINT64_C(0), // SLL
|
||
|
UINT64_C(9216), // SLL16_MM
|
||
|
UINT64_C(9216), // SLL16_MMR6
|
||
|
UINT64_C(0), // SLL64_32
|
||
|
UINT64_C(0), // SLL64_64
|
||
|
UINT64_C(2020605961), // SLLI_B
|
||
|
UINT64_C(2013265929), // SLLI_D
|
||
|
UINT64_C(2019557385), // SLLI_H
|
||
|
UINT64_C(2017460233), // SLLI_W
|
||
|
UINT64_C(4), // SLLV
|
||
|
UINT64_C(16), // SLLV_MM
|
||
|
UINT64_C(2013265933), // SLL_B
|
||
|
UINT64_C(2019557389), // SLL_D
|
||
|
UINT64_C(2015363085), // SLL_H
|
||
|
UINT64_C(0), // SLL_MM
|
||
|
UINT64_C(0), // SLL_MMR6
|
||
|
UINT64_C(2017460237), // SLL_W
|
||
|
UINT64_C(42), // SLT
|
||
|
UINT64_C(42), // SLT64
|
||
|
UINT64_C(848), // SLT_MM
|
||
|
UINT64_C(671088640), // SLTi
|
||
|
UINT64_C(671088640), // SLTi64
|
||
|
UINT64_C(2415919104), // SLTi_MM
|
||
|
UINT64_C(738197504), // SLTiu
|
||
|
UINT64_C(738197504), // SLTiu64
|
||
|
UINT64_C(2952790016), // SLTiu_MM
|
||
|
UINT64_C(43), // SLTu
|
||
|
UINT64_C(43), // SLTu64
|
||
|
UINT64_C(912), // SLTu_MM
|
||
|
UINT64_C(1879048235), // SNE
|
||
|
UINT64_C(1879048239), // SNEi
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2017460249), // SPLATI_B
|
||
|
UINT64_C(2021130265), // SPLATI_D
|
||
|
UINT64_C(2019557401), // SPLATI_H
|
||
|
UINT64_C(2020605977), // SPLATI_W
|
||
|
UINT64_C(2021654548), // SPLAT_B
|
||
|
UINT64_C(2027946004), // SPLAT_D
|
||
|
UINT64_C(2023751700), // SPLAT_H
|
||
|
UINT64_C(2025848852), // SPLAT_W
|
||
|
UINT64_C(1409305147), // SQRT_D_MMR6
|
||
|
UINT64_C(1409288763), // SQRT_S_MMR6
|
||
|
UINT64_C(3), // SRA
|
||
|
UINT64_C(2028994569), // SRAI_B
|
||
|
UINT64_C(2021654537), // SRAI_D
|
||
|
UINT64_C(2027945993), // SRAI_H
|
||
|
UINT64_C(2025848841), // SRAI_W
|
||
|
UINT64_C(2037383178), // SRARI_B
|
||
|
UINT64_C(2030043146), // SRARI_D
|
||
|
UINT64_C(2036334602), // SRARI_H
|
||
|
UINT64_C(2034237450), // SRARI_W
|
||
|
UINT64_C(2021654549), // SRAR_B
|
||
|
UINT64_C(2027946005), // SRAR_D
|
||
|
UINT64_C(2023751701), // SRAR_H
|
||
|
UINT64_C(2025848853), // SRAR_W
|
||
|
UINT64_C(7), // SRAV
|
||
|
UINT64_C(144), // SRAV_MM
|
||
|
UINT64_C(2021654541), // SRA_B
|
||
|
UINT64_C(2027945997), // SRA_D
|
||
|
UINT64_C(2023751693), // SRA_H
|
||
|
UINT64_C(128), // SRA_MM
|
||
|
UINT64_C(2025848845), // SRA_W
|
||
|
UINT64_C(2), // SRL
|
||
|
UINT64_C(9217), // SRL16_MM
|
||
|
UINT64_C(9217), // SRL16_MMR6
|
||
|
UINT64_C(2037383177), // SRLI_B
|
||
|
UINT64_C(2030043145), // SRLI_D
|
||
|
UINT64_C(2036334601), // SRLI_H
|
||
|
UINT64_C(2034237449), // SRLI_W
|
||
|
UINT64_C(2045771786), // SRLRI_B
|
||
|
UINT64_C(2038431754), // SRLRI_D
|
||
|
UINT64_C(2044723210), // SRLRI_H
|
||
|
UINT64_C(2042626058), // SRLRI_W
|
||
|
UINT64_C(2030043157), // SRLR_B
|
||
|
UINT64_C(2036334613), // SRLR_D
|
||
|
UINT64_C(2032140309), // SRLR_H
|
||
|
UINT64_C(2034237461), // SRLR_W
|
||
|
UINT64_C(6), // SRLV
|
||
|
UINT64_C(80), // SRLV_MM
|
||
|
UINT64_C(2030043149), // SRL_B
|
||
|
UINT64_C(2036334605), // SRL_D
|
||
|
UINT64_C(2032140301), // SRL_H
|
||
|
UINT64_C(64), // SRL_MM
|
||
|
UINT64_C(2034237453), // SRL_W
|
||
|
UINT64_C(64), // SSNOP
|
||
|
UINT64_C(2048), // SSNOP_MM
|
||
|
UINT64_C(2048), // SSNOP_MMR6
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(2013265956), // ST_B
|
||
|
UINT64_C(2013265959), // ST_D
|
||
|
UINT64_C(2013265957), // ST_H
|
||
|
UINT64_C(2013265958), // ST_W
|
||
|
UINT64_C(34), // SUB
|
||
|
UINT64_C(2080375384), // SUBQH_PH
|
||
|
UINT64_C(589), // SUBQH_PH_MMR2
|
||
|
UINT64_C(2080375512), // SUBQH_R_PH
|
||
|
UINT64_C(1613), // SUBQH_R_PH_MMR2
|
||
|
UINT64_C(2080376024), // SUBQH_R_W
|
||
|
UINT64_C(1677), // SUBQH_R_W_MMR2
|
||
|
UINT64_C(2080375896), // SUBQH_W
|
||
|
UINT64_C(653), // SUBQH_W_MMR2
|
||
|
UINT64_C(2080375504), // SUBQ_PH
|
||
|
UINT64_C(525), // SUBQ_PH_MM
|
||
|
UINT64_C(2080375760), // SUBQ_S_PH
|
||
|
UINT64_C(1549), // SUBQ_S_PH_MM
|
||
|
UINT64_C(2080376272), // SUBQ_S_W
|
||
|
UINT64_C(837), // SUBQ_S_W_MM
|
||
|
UINT64_C(2030043153), // SUBSUS_U_B
|
||
|
UINT64_C(2036334609), // SUBSUS_U_D
|
||
|
UINT64_C(2032140305), // SUBSUS_U_H
|
||
|
UINT64_C(2034237457), // SUBSUS_U_W
|
||
|
UINT64_C(2038431761), // SUBSUU_S_B
|
||
|
UINT64_C(2044723217), // SUBSUU_S_D
|
||
|
UINT64_C(2040528913), // SUBSUU_S_H
|
||
|
UINT64_C(2042626065), // SUBSUU_S_W
|
||
|
UINT64_C(2013265937), // SUBS_S_B
|
||
|
UINT64_C(2019557393), // SUBS_S_D
|
||
|
UINT64_C(2015363089), // SUBS_S_H
|
||
|
UINT64_C(2017460241), // SUBS_S_W
|
||
|
UINT64_C(2021654545), // SUBS_U_B
|
||
|
UINT64_C(2027946001), // SUBS_U_D
|
||
|
UINT64_C(2023751697), // SUBS_U_H
|
||
|
UINT64_C(2025848849), // SUBS_U_W
|
||
|
UINT64_C(1025), // SUBU16_MM
|
||
|
UINT64_C(1025), // SUBU16_MMR6
|
||
|
UINT64_C(2080374872), // SUBUH_QB
|
||
|
UINT64_C(845), // SUBUH_QB_MMR2
|
||
|
UINT64_C(2080375000), // SUBUH_R_QB
|
||
|
UINT64_C(1869), // SUBUH_R_QB_MMR2
|
||
|
UINT64_C(464), // SUBU_MMR6
|
||
|
UINT64_C(2080375376), // SUBU_PH
|
||
|
UINT64_C(781), // SUBU_PH_MMR2
|
||
|
UINT64_C(2080374864), // SUBU_QB
|
||
|
UINT64_C(717), // SUBU_QB_MM
|
||
|
UINT64_C(2080375632), // SUBU_S_PH
|
||
|
UINT64_C(1805), // SUBU_S_PH_MMR2
|
||
|
UINT64_C(2080375120), // SUBU_S_QB
|
||
|
UINT64_C(1741), // SUBU_S_QB_MM
|
||
|
UINT64_C(2021654534), // SUBVI_B
|
||
|
UINT64_C(2027945990), // SUBVI_D
|
||
|
UINT64_C(2023751686), // SUBVI_H
|
||
|
UINT64_C(2025848838), // SUBVI_W
|
||
|
UINT64_C(2021654542), // SUBV_B
|
||
|
UINT64_C(2027945998), // SUBV_D
|
||
|
UINT64_C(2023751694), // SUBV_H
|
||
|
UINT64_C(2025848846), // SUBV_W
|
||
|
UINT64_C(400), // SUB_MM
|
||
|
UINT64_C(400), // SUB_MMR6
|
||
|
UINT64_C(35), // SUBu
|
||
|
UINT64_C(464), // SUBu_MM
|
||
|
UINT64_C(1275068429), // SUXC1
|
||
|
UINT64_C(1275068429), // SUXC164
|
||
|
UINT64_C(1409286536), // SUXC1_MM
|
||
|
UINT64_C(2885681152), // SW
|
||
|
UINT64_C(59392), // SW16_MM
|
||
|
UINT64_C(59392), // SW16_MMR6
|
||
|
UINT64_C(2885681152), // SW64
|
||
|
UINT64_C(3825205248), // SWC1
|
||
|
UINT64_C(2550136832), // SWC1_MM
|
||
|
UINT64_C(3892314112), // SWC2
|
||
|
UINT64_C(1231028224), // SWC2_R6
|
||
|
UINT64_C(3959422976), // SWC3
|
||
|
UINT64_C(2080374815), // SWE
|
||
|
UINT64_C(1610657280), // SWE_MM
|
||
|
UINT64_C(1610657280), // SWE_MMR6
|
||
|
UINT64_C(2818572288), // SWL
|
||
|
UINT64_C(2818572288), // SWL64
|
||
|
UINT64_C(2080374817), // SWLE
|
||
|
UINT64_C(1610653696), // SWLE_MM
|
||
|
UINT64_C(1610645504), // SWL_MM
|
||
|
UINT64_C(17728), // SWM16_MM
|
||
|
UINT64_C(17418), // SWM16_MMR6
|
||
|
UINT64_C(536924160), // SWM32_MM
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(536907776), // SWP_MM
|
||
|
UINT64_C(3087007744), // SWR
|
||
|
UINT64_C(3087007744), // SWR64
|
||
|
UINT64_C(2080374818), // SWRE
|
||
|
UINT64_C(1610654208), // SWRE_MM
|
||
|
UINT64_C(1610649600), // SWR_MM
|
||
|
UINT64_C(51200), // SWSP_MM
|
||
|
UINT64_C(51200), // SWSP_MMR6
|
||
|
UINT64_C(1275068424), // SWXC1
|
||
|
UINT64_C(1409286280), // SWXC1_MM
|
||
|
UINT64_C(4160749568), // SW_MM
|
||
|
UINT64_C(4160749568), // SW_MMR6
|
||
|
UINT64_C(15), // SYNC
|
||
|
UINT64_C(69140480), // SYNCI
|
||
|
UINT64_C(1098907648), // SYNCI_MMR6
|
||
|
UINT64_C(27516), // SYNC_MM
|
||
|
UINT64_C(27516), // SYNC_MMR6
|
||
|
UINT64_C(12), // SYSCALL
|
||
|
UINT64_C(35708), // SYSCALL_MM
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(25728), // Save16
|
||
|
UINT64_C(25728), // SaveX16
|
||
|
UINT64_C(4026580992), // SbRxRyOffMemX16
|
||
|
UINT64_C(59537), // SebRx16
|
||
|
UINT64_C(59569), // SehRx16
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(4026583040), // ShRxRyOffMemX16
|
||
|
UINT64_C(4026544128), // SllX16
|
||
|
UINT64_C(59396), // SllvRxRy16
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(59394), // SltRxRy16
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(20480), // SltiRxImm16
|
||
|
UINT64_C(4026552320), // SltiRxImmX16
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(22528), // SltiuRxImm16
|
||
|
UINT64_C(4026554368), // SltiuRxImmX16
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(59395), // SltuRxRy16
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(4026544131), // SraX16
|
||
|
UINT64_C(59399), // SravRxRy16
|
||
|
UINT64_C(4026544130), // SrlX16
|
||
|
UINT64_C(59398), // SrlvRxRy16
|
||
|
UINT64_C(57347), // SubuRxRyRz16
|
||
|
UINT64_C(4026587136), // SwRxRyOffMemX16
|
||
|
UINT64_C(4026585088), // SwRxSpImmX16
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(52), // TEQ
|
||
|
UINT64_C(67895296), // TEQI
|
||
|
UINT64_C(1103101952), // TEQI_MM
|
||
|
UINT64_C(60), // TEQ_MM
|
||
|
UINT64_C(48), // TGE
|
||
|
UINT64_C(67633152), // TGEI
|
||
|
UINT64_C(67698688), // TGEIU
|
||
|
UINT64_C(1096810496), // TGEIU_MM
|
||
|
UINT64_C(1092616192), // TGEI_MM
|
||
|
UINT64_C(49), // TGEU
|
||
|
UINT64_C(1084), // TGEU_MM
|
||
|
UINT64_C(572), // TGE_MM
|
||
|
UINT64_C(1107296259), // TLBINV
|
||
|
UINT64_C(1107296260), // TLBINVF
|
||
|
UINT64_C(1107296264), // TLBP
|
||
|
UINT64_C(892), // TLBP_MM
|
||
|
UINT64_C(1107296257), // TLBR
|
||
|
UINT64_C(4988), // TLBR_MM
|
||
|
UINT64_C(1107296258), // TLBWI
|
||
|
UINT64_C(9084), // TLBWI_MM
|
||
|
UINT64_C(1107296262), // TLBWR
|
||
|
UINT64_C(13180), // TLBWR_MM
|
||
|
UINT64_C(50), // TLT
|
||
|
UINT64_C(67764224), // TLTI
|
||
|
UINT64_C(1094713344), // TLTIU_MM
|
||
|
UINT64_C(1090519040), // TLTI_MM
|
||
|
UINT64_C(51), // TLTU
|
||
|
UINT64_C(2620), // TLTU_MM
|
||
|
UINT64_C(2108), // TLT_MM
|
||
|
UINT64_C(54), // TNE
|
||
|
UINT64_C(68026368), // TNEI
|
||
|
UINT64_C(1098907648), // TNEI_MM
|
||
|
UINT64_C(3132), // TNE_MM
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(1176502281), // TRUNC_L_D64
|
||
|
UINT64_C(1409311547), // TRUNC_L_D_MMR6
|
||
|
UINT64_C(1174405129), // TRUNC_L_S
|
||
|
UINT64_C(1409295163), // TRUNC_L_S_MMR6
|
||
|
UINT64_C(1176502285), // TRUNC_W_D32
|
||
|
UINT64_C(1176502285), // TRUNC_W_D64
|
||
|
UINT64_C(1409313595), // TRUNC_W_D_MMR6
|
||
|
UINT64_C(1409313595), // TRUNC_W_MM
|
||
|
UINT64_C(1174405133), // TRUNC_W_S
|
||
|
UINT64_C(1409297211), // TRUNC_W_S_MM
|
||
|
UINT64_C(1409297211), // TRUNC_W_S_MMR6
|
||
|
UINT64_C(67829760), // TTLTIU
|
||
|
UINT64_C(27), // UDIV
|
||
|
UINT64_C(47932), // UDIV_MM
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(1879048209), // V3MULU
|
||
|
UINT64_C(1879048208), // VMM0
|
||
|
UINT64_C(1879048207), // VMULU
|
||
|
UINT64_C(2013265941), // VSHF_B
|
||
|
UINT64_C(2019557397), // VSHF_D
|
||
|
UINT64_C(2015363093), // VSHF_H
|
||
|
UINT64_C(2017460245), // VSHF_W
|
||
|
UINT64_C(1107296288), // WAIT
|
||
|
UINT64_C(37756), // WAIT_MM
|
||
|
UINT64_C(37756), // WAIT_MMR6
|
||
|
UINT64_C(2080376056), // WRDSP
|
||
|
UINT64_C(5756), // WRDSP_MM
|
||
|
UINT64_C(61820), // WRPGPR_MMR6
|
||
|
UINT64_C(2080374944), // WSBH
|
||
|
UINT64_C(31548), // WSBH_MM
|
||
|
UINT64_C(31548), // WSBH_MMR6
|
||
|
UINT64_C(38), // XOR
|
||
|
UINT64_C(17472), // XOR16_MM
|
||
|
UINT64_C(17416), // XOR16_MMR6
|
||
|
UINT64_C(38), // XOR64
|
||
|
UINT64_C(2063597568), // XORI_B
|
||
|
UINT64_C(1879048192), // XORI_MMR6
|
||
|
UINT64_C(784), // XOR_MM
|
||
|
UINT64_C(784), // XOR_MMR6
|
||
|
UINT64_C(2019557406), // XOR_V
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(0),
|
||
|
UINT64_C(939524096), // XORi
|
||
|
UINT64_C(939524096), // XORi64
|
||
|
UINT64_C(1879048192), // XORi_MM
|
||
|
UINT64_C(59406), // XorRxRxRy16
|
||
|
UINT64_C(0)
|
||
|
};
|
||
|
const unsigned opcode = MI.getOpcode();
|
||
|
uint64_t Value = InstBits[opcode];
|
||
|
uint64_t op = 0;
|
||
|
(void)op; // suppress warning
|
||
|
switch (opcode) {
|
||
|
case Mips::Break16:
|
||
|
case Mips::DERET:
|
||
|
case Mips::DERET_MM:
|
||
|
case Mips::DERET_MMR6:
|
||
|
case Mips::EHB:
|
||
|
case Mips::EHB_MM:
|
||
|
case Mips::EHB_MMR6:
|
||
|
case Mips::ERET:
|
||
|
case Mips::ERETNC:
|
||
|
case Mips::ERETNC_MMR6:
|
||
|
case Mips::ERET_MM:
|
||
|
case Mips::ERET_MMR6:
|
||
|
case Mips::JrRa16:
|
||
|
case Mips::JrcRa16:
|
||
|
case Mips::PAUSE:
|
||
|
case Mips::PAUSE_MM:
|
||
|
case Mips::PAUSE_MMR6:
|
||
|
case Mips::Restore16:
|
||
|
case Mips::RestoreX16:
|
||
|
case Mips::SSNOP:
|
||
|
case Mips::SSNOP_MM:
|
||
|
case Mips::SSNOP_MMR6:
|
||
|
case Mips::Save16:
|
||
|
case Mips::SaveX16:
|
||
|
case Mips::TLBINV:
|
||
|
case Mips::TLBINVF:
|
||
|
case Mips::TLBP:
|
||
|
case Mips::TLBP_MM:
|
||
|
case Mips::TLBR:
|
||
|
case Mips::TLBR_MM:
|
||
|
case Mips::TLBWI:
|
||
|
case Mips::TLBWI_MM:
|
||
|
case Mips::TLBWR:
|
||
|
case Mips::TLBWR_MM:
|
||
|
case Mips::WAIT: {
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MTHLIP:
|
||
|
case Mips::SHILOV: {
|
||
|
// op: ac
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 11;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DPAQX_SA_W_PH:
|
||
|
case Mips::DPAQX_S_W_PH:
|
||
|
case Mips::DPAQ_SA_L_W:
|
||
|
case Mips::DPAQ_S_W_PH:
|
||
|
case Mips::DPAU_H_QBL:
|
||
|
case Mips::DPAU_H_QBR:
|
||
|
case Mips::DPAX_W_PH:
|
||
|
case Mips::DPA_W_PH:
|
||
|
case Mips::DPSQX_SA_W_PH:
|
||
|
case Mips::DPSQX_S_W_PH:
|
||
|
case Mips::DPSQ_SA_L_W:
|
||
|
case Mips::DPSQ_S_W_PH:
|
||
|
case Mips::DPSU_H_QBL:
|
||
|
case Mips::DPSU_H_QBR:
|
||
|
case Mips::DPSX_W_PH:
|
||
|
case Mips::DPS_W_PH:
|
||
|
case Mips::MADDU_DSP:
|
||
|
case Mips::MADD_DSP:
|
||
|
case Mips::MAQ_SA_W_PHL:
|
||
|
case Mips::MAQ_SA_W_PHR:
|
||
|
case Mips::MAQ_S_W_PHL:
|
||
|
case Mips::MAQ_S_W_PHR:
|
||
|
case Mips::MSUBU_DSP:
|
||
|
case Mips::MSUB_DSP:
|
||
|
case Mips::MULSAQ_S_W_PH:
|
||
|
case Mips::MULSA_W_PH:
|
||
|
case Mips::MULTU_DSP:
|
||
|
case Mips::MULT_DSP: {
|
||
|
// op: ac
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 11;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SHILO: {
|
||
|
// op: ac
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 11;
|
||
|
// op: shift
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(63)) << 20;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LD_B:
|
||
|
case Mips::LD_D:
|
||
|
case Mips::LD_H:
|
||
|
case Mips::LD_W:
|
||
|
case Mips::ST_B:
|
||
|
case Mips::ST_D:
|
||
|
case Mips::ST_H:
|
||
|
case Mips::ST_W: {
|
||
|
// op: addr
|
||
|
op = getMSAMemEncoding(MI, 1, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(1023)) << 16;
|
||
|
Value |= (op & UINT64_C(2031616)) >> 5;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CACHEE:
|
||
|
case Mips::CACHE_R6:
|
||
|
case Mips::PREFE:
|
||
|
case Mips::PREF_R6: {
|
||
|
// op: addr
|
||
|
op = getMemEncoding(MI, 0, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(2031616)) << 5;
|
||
|
Value |= (op & UINT64_C(511)) << 7;
|
||
|
// op: hint
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SYNCI: {
|
||
|
// op: addr
|
||
|
op = getMemEncoding(MI, 0, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(2031616)) << 5;
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CACHE:
|
||
|
case Mips::PREF: {
|
||
|
// op: addr
|
||
|
op = getMemEncoding(MI, 0, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(2031616)) << 5;
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
// op: hint
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SYNCI_MMR6: {
|
||
|
// op: addr
|
||
|
op = getMemEncoding(MI, 0, Fixups, STI);
|
||
|
Value |= op & UINT64_C(2097151);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LBE:
|
||
|
case Mips::LBuE:
|
||
|
case Mips::LHE:
|
||
|
case Mips::LHuE:
|
||
|
case Mips::LLE:
|
||
|
case Mips::LWE:
|
||
|
case Mips::LWLE:
|
||
|
case Mips::LWRE:
|
||
|
case Mips::SBE:
|
||
|
case Mips::SHE:
|
||
|
case Mips::SWE:
|
||
|
case Mips::SWLE:
|
||
|
case Mips::SWRE: {
|
||
|
// op: addr
|
||
|
op = getMemEncoding(MI, 1, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(2031616)) << 5;
|
||
|
Value |= (op & UINT64_C(511)) << 7;
|
||
|
// op: hint
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SCE: {
|
||
|
// op: addr
|
||
|
op = getMemEncoding(MI, 2, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(2031616)) << 5;
|
||
|
Value |= (op & UINT64_C(511)) << 7;
|
||
|
// op: hint
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CACHE_MM:
|
||
|
case Mips::CACHE_MMR6:
|
||
|
case Mips::PREF_MM:
|
||
|
case Mips::PREF_MMR6: {
|
||
|
// op: addr
|
||
|
op = getMemEncodingMMImm12(MI, 0, Fixups, STI);
|
||
|
Value |= op & UINT64_C(2031616);
|
||
|
Value |= op & UINT64_C(4095);
|
||
|
// op: hint
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LBU_MMR6:
|
||
|
case Mips::LB_MMR6: {
|
||
|
// op: addr
|
||
|
op = getMemEncodingMMImm16(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(2097151);
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CACHEE_MM:
|
||
|
case Mips::CACHEE_MMR6:
|
||
|
case Mips::PREFE_MM:
|
||
|
case Mips::PREFE_MMR6: {
|
||
|
// op: addr
|
||
|
op = getMemEncodingMMImm9(MI, 0, Fixups, STI);
|
||
|
Value |= op & UINT64_C(2031616);
|
||
|
Value |= op & UINT64_C(511);
|
||
|
// op: hint
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LBE_MMR6:
|
||
|
case Mips::LBUE_MMR6: {
|
||
|
// op: addr
|
||
|
op = getMemEncodingMMImm9(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(2031616);
|
||
|
Value |= op & UINT64_C(511);
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SDBBP_MM:
|
||
|
case Mips::SDBBP_MMR6:
|
||
|
case Mips::SYSCALL_MM:
|
||
|
case Mips::WAIT_MM:
|
||
|
case Mips::WAIT_MMR6: {
|
||
|
// op: code_
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(1023)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SDBBP:
|
||
|
case Mips::SDBBP_R6:
|
||
|
case Mips::SYSCALL: {
|
||
|
// op: code_
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(1048575)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BREAK16_MMR6:
|
||
|
case Mips::SDBBP16_MMR6: {
|
||
|
// op: code_
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(15)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BREAK16_MM:
|
||
|
case Mips::SDBBP16_MM: {
|
||
|
// op: code_
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= op & UINT64_C(15);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BREAK:
|
||
|
case Mips::BREAK_MM:
|
||
|
case Mips::BREAK_MMR6: {
|
||
|
// op: code_1
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(1023)) << 16;
|
||
|
// op: code_2
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(1023)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BC2EQZ:
|
||
|
case Mips::BC2NEZ: {
|
||
|
// op: ct
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: offset
|
||
|
op = getBranchTargetOpValue(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MOVEP_MM: {
|
||
|
// op: dst_regs
|
||
|
op = getMovePRegPairOpValue(MI, 0, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 7;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 4;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 1;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BC1F:
|
||
|
case Mips::BC1FL:
|
||
|
case Mips::BC1T:
|
||
|
case Mips::BC1TL: {
|
||
|
// op: fcc
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 18;
|
||
|
// op: offset
|
||
|
op = getBranchTargetOpValue(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LUXC1_MM:
|
||
|
case Mips::LWXC1_MM: {
|
||
|
// op: fd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: base
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: index
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MOVN_I_D32_MM:
|
||
|
case Mips::MOVN_I_S_MM:
|
||
|
case Mips::MOVZ_I_D32_MM:
|
||
|
case Mips::MOVZ_I_S_MM: {
|
||
|
// op: fd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CEIL_W_MM:
|
||
|
case Mips::CEIL_W_S_MM:
|
||
|
case Mips::CVT_D32_W_MM:
|
||
|
case Mips::CVT_D_S_MM:
|
||
|
case Mips::CVT_L_D64_MM:
|
||
|
case Mips::CVT_L_S_MM:
|
||
|
case Mips::CVT_S_D32_MM:
|
||
|
case Mips::CVT_S_W_MM:
|
||
|
case Mips::CVT_W_MM:
|
||
|
case Mips::CVT_W_S_MM:
|
||
|
case Mips::FABS_MM:
|
||
|
case Mips::FABS_S_MM:
|
||
|
case Mips::FLOOR_W_MM:
|
||
|
case Mips::FLOOR_W_S_MM:
|
||
|
case Mips::FMOV_D32_MM:
|
||
|
case Mips::FMOV_S_MM:
|
||
|
case Mips::FNEG_MM:
|
||
|
case Mips::FNEG_S_MM:
|
||
|
case Mips::FSQRT_MM:
|
||
|
case Mips::FSQRT_S_MM:
|
||
|
case Mips::MOVF_D32_MM:
|
||
|
case Mips::MOVF_S_MM:
|
||
|
case Mips::MOVT_D32_MM:
|
||
|
case Mips::MOVT_S_MM:
|
||
|
case Mips::ROUND_W_MM:
|
||
|
case Mips::ROUND_W_S_MM:
|
||
|
case Mips::TRUNC_W_MM:
|
||
|
case Mips::TRUNC_W_S_MM: {
|
||
|
// op: fd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LDXC1:
|
||
|
case Mips::LDXC164:
|
||
|
case Mips::LUXC1:
|
||
|
case Mips::LUXC164:
|
||
|
case Mips::LWXC1: {
|
||
|
// op: fd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: base
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: index
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MADD_D32:
|
||
|
case Mips::MADD_D64:
|
||
|
case Mips::MADD_S:
|
||
|
case Mips::MSUB_D32:
|
||
|
case Mips::MSUB_D64:
|
||
|
case Mips::MSUB_S:
|
||
|
case Mips::NMADD_D32:
|
||
|
case Mips::NMADD_D64:
|
||
|
case Mips::NMADD_S:
|
||
|
case Mips::NMSUB_D32:
|
||
|
case Mips::NMSUB_D64:
|
||
|
case Mips::NMSUB_S: {
|
||
|
// op: fd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: fr
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: ft
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CEIL_L_D64:
|
||
|
case Mips::CEIL_L_S:
|
||
|
case Mips::CEIL_W_D32:
|
||
|
case Mips::CEIL_W_D64:
|
||
|
case Mips::CEIL_W_S:
|
||
|
case Mips::CVT_D32_S:
|
||
|
case Mips::CVT_D32_W:
|
||
|
case Mips::CVT_D64_L:
|
||
|
case Mips::CVT_D64_S:
|
||
|
case Mips::CVT_D64_W:
|
||
|
case Mips::CVT_L_D64:
|
||
|
case Mips::CVT_L_S:
|
||
|
case Mips::CVT_S_D32:
|
||
|
case Mips::CVT_S_D64:
|
||
|
case Mips::CVT_S_L:
|
||
|
case Mips::CVT_S_W:
|
||
|
case Mips::CVT_W_D32:
|
||
|
case Mips::CVT_W_D64:
|
||
|
case Mips::CVT_W_S:
|
||
|
case Mips::FABS_D32:
|
||
|
case Mips::FABS_D64:
|
||
|
case Mips::FABS_S:
|
||
|
case Mips::FLOOR_L_D64:
|
||
|
case Mips::FLOOR_L_S:
|
||
|
case Mips::FLOOR_W_D32:
|
||
|
case Mips::FLOOR_W_D64:
|
||
|
case Mips::FLOOR_W_S:
|
||
|
case Mips::FMOV_D32:
|
||
|
case Mips::FMOV_D64:
|
||
|
case Mips::FMOV_S:
|
||
|
case Mips::FNEG_D32:
|
||
|
case Mips::FNEG_D64:
|
||
|
case Mips::FNEG_S:
|
||
|
case Mips::FSQRT_D32:
|
||
|
case Mips::FSQRT_D64:
|
||
|
case Mips::FSQRT_S:
|
||
|
case Mips::ROUND_L_D64:
|
||
|
case Mips::ROUND_L_S:
|
||
|
case Mips::ROUND_W_D32:
|
||
|
case Mips::ROUND_W_D64:
|
||
|
case Mips::ROUND_W_S:
|
||
|
case Mips::TRUNC_L_D64:
|
||
|
case Mips::TRUNC_L_S:
|
||
|
case Mips::TRUNC_W_D32:
|
||
|
case Mips::TRUNC_W_D64:
|
||
|
case Mips::TRUNC_W_S: {
|
||
|
// op: fd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MOVF_D32:
|
||
|
case Mips::MOVF_D64:
|
||
|
case Mips::MOVF_S:
|
||
|
case Mips::MOVT_D32:
|
||
|
case Mips::MOVT_D64:
|
||
|
case Mips::MOVT_S: {
|
||
|
// op: fd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: fcc
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 18;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CMP_EQ_D:
|
||
|
case Mips::CMP_EQ_S:
|
||
|
case Mips::CMP_F_D:
|
||
|
case Mips::CMP_F_S:
|
||
|
case Mips::CMP_LE_D:
|
||
|
case Mips::CMP_LE_S:
|
||
|
case Mips::CMP_LT_D:
|
||
|
case Mips::CMP_LT_S:
|
||
|
case Mips::CMP_SAF_D:
|
||
|
case Mips::CMP_SAF_S:
|
||
|
case Mips::CMP_SEQ_D:
|
||
|
case Mips::CMP_SEQ_S:
|
||
|
case Mips::CMP_SLE_D:
|
||
|
case Mips::CMP_SLE_S:
|
||
|
case Mips::CMP_SLT_D:
|
||
|
case Mips::CMP_SLT_S:
|
||
|
case Mips::CMP_SUEQ_D:
|
||
|
case Mips::CMP_SUEQ_S:
|
||
|
case Mips::CMP_SULE_D:
|
||
|
case Mips::CMP_SULE_S:
|
||
|
case Mips::CMP_SULT_D:
|
||
|
case Mips::CMP_SULT_S:
|
||
|
case Mips::CMP_SUN_D:
|
||
|
case Mips::CMP_SUN_S:
|
||
|
case Mips::CMP_UEQ_D:
|
||
|
case Mips::CMP_UEQ_S:
|
||
|
case Mips::CMP_ULE_D:
|
||
|
case Mips::CMP_ULE_S:
|
||
|
case Mips::CMP_ULT_D:
|
||
|
case Mips::CMP_ULT_S:
|
||
|
case Mips::CMP_UN_D:
|
||
|
case Mips::CMP_UN_S:
|
||
|
case Mips::FADD_D32:
|
||
|
case Mips::FADD_D64:
|
||
|
case Mips::FADD_S:
|
||
|
case Mips::FDIV_D32:
|
||
|
case Mips::FDIV_D64:
|
||
|
case Mips::FDIV_S:
|
||
|
case Mips::FMUL_D32:
|
||
|
case Mips::FMUL_D64:
|
||
|
case Mips::FMUL_S:
|
||
|
case Mips::FSUB_D32:
|
||
|
case Mips::FSUB_D64:
|
||
|
case Mips::FSUB_S: {
|
||
|
// op: fd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: ft
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MOVN_I64_D64:
|
||
|
case Mips::MOVN_I64_S:
|
||
|
case Mips::MOVN_I_D32:
|
||
|
case Mips::MOVN_I_D64:
|
||
|
case Mips::MOVN_I_S:
|
||
|
case Mips::MOVZ_I64_D64:
|
||
|
case Mips::MOVZ_I64_S:
|
||
|
case Mips::MOVZ_I_D32:
|
||
|
case Mips::MOVZ_I_D64:
|
||
|
case Mips::MOVZ_I_S: {
|
||
|
// op: fd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SUXC1_MM:
|
||
|
case Mips::SWXC1_MM: {
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: base
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: index
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SDXC1:
|
||
|
case Mips::SDXC164:
|
||
|
case Mips::SUXC1:
|
||
|
case Mips::SUXC164:
|
||
|
case Mips::SWXC1: {
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: base
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: index
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::C_EQ_D32:
|
||
|
case Mips::C_EQ_D64:
|
||
|
case Mips::C_EQ_S:
|
||
|
case Mips::C_F_D32:
|
||
|
case Mips::C_F_D64:
|
||
|
case Mips::C_F_S:
|
||
|
case Mips::C_LE_D32:
|
||
|
case Mips::C_LE_D64:
|
||
|
case Mips::C_LE_S:
|
||
|
case Mips::C_LT_D32:
|
||
|
case Mips::C_LT_D64:
|
||
|
case Mips::C_LT_S:
|
||
|
case Mips::C_NGE_D32:
|
||
|
case Mips::C_NGE_D64:
|
||
|
case Mips::C_NGE_S:
|
||
|
case Mips::C_NGLE_D32:
|
||
|
case Mips::C_NGLE_D64:
|
||
|
case Mips::C_NGLE_S:
|
||
|
case Mips::C_NGL_D32:
|
||
|
case Mips::C_NGL_D64:
|
||
|
case Mips::C_NGL_S:
|
||
|
case Mips::C_NGT_D32:
|
||
|
case Mips::C_NGT_D64:
|
||
|
case Mips::C_NGT_S:
|
||
|
case Mips::C_OLE_D32:
|
||
|
case Mips::C_OLE_D64:
|
||
|
case Mips::C_OLE_S:
|
||
|
case Mips::C_OLT_D32:
|
||
|
case Mips::C_OLT_D64:
|
||
|
case Mips::C_OLT_S:
|
||
|
case Mips::C_SEQ_D32:
|
||
|
case Mips::C_SEQ_D64:
|
||
|
case Mips::C_SEQ_S:
|
||
|
case Mips::C_SF_D32:
|
||
|
case Mips::C_SF_D64:
|
||
|
case Mips::C_SF_S:
|
||
|
case Mips::C_UEQ_D32:
|
||
|
case Mips::C_UEQ_D64:
|
||
|
case Mips::C_UEQ_S:
|
||
|
case Mips::C_ULE_D32:
|
||
|
case Mips::C_ULE_D64:
|
||
|
case Mips::C_ULE_S:
|
||
|
case Mips::C_ULT_D32:
|
||
|
case Mips::C_ULT_D64:
|
||
|
case Mips::C_ULT_S:
|
||
|
case Mips::C_UN_D32:
|
||
|
case Mips::C_UN_D64:
|
||
|
case Mips::C_UN_S: {
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: ft
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::FCMP_D32:
|
||
|
case Mips::FCMP_D64:
|
||
|
case Mips::FCMP_S32: {
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: ft
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: cond
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= op & UINT64_C(15);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::FCMP_D32_MM:
|
||
|
case Mips::FCMP_S32_MM: {
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: ft
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: cond
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(15)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CLASS_D:
|
||
|
case Mips::CLASS_S:
|
||
|
case Mips::RINT_D:
|
||
|
case Mips::RINT_S: {
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: fd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CLASS_D_MMR6:
|
||
|
case Mips::CLASS_S_MMR6:
|
||
|
case Mips::RINT_D_MMR6:
|
||
|
case Mips::RINT_S_MMR6: {
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: fd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BC1EQZ:
|
||
|
case Mips::BC1NEZ: {
|
||
|
// op: ft
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: offset
|
||
|
op = getBranchTargetOpValue(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ABS_D_MMR6:
|
||
|
case Mips::ABS_S_MMR6:
|
||
|
case Mips::CEIL_L_D_MMR6:
|
||
|
case Mips::CEIL_L_S_MMR6:
|
||
|
case Mips::CEIL_W_D_MMR6:
|
||
|
case Mips::CEIL_W_S_MMR6:
|
||
|
case Mips::CVT_D_L_MMR6:
|
||
|
case Mips::CVT_D_S_MMR6:
|
||
|
case Mips::CVT_D_W_MMR6:
|
||
|
case Mips::CVT_L_D_MMR6:
|
||
|
case Mips::CVT_L_S_MMR6:
|
||
|
case Mips::CVT_S_D_MMR6:
|
||
|
case Mips::CVT_S_L_MMR6:
|
||
|
case Mips::CVT_S_W_MMR6:
|
||
|
case Mips::CVT_W_D_MMR6:
|
||
|
case Mips::CVT_W_S_MMR6:
|
||
|
case Mips::FLOOR_L_D_MMR6:
|
||
|
case Mips::FLOOR_L_S_MMR6:
|
||
|
case Mips::FLOOR_W_D_MMR6:
|
||
|
case Mips::FLOOR_W_S_MMR6:
|
||
|
case Mips::FMOV_D_MMR6:
|
||
|
case Mips::FMOV_S_MMR6:
|
||
|
case Mips::FNEG_D_MMR6:
|
||
|
case Mips::FNEG_S_MMR6:
|
||
|
case Mips::RECIP_D_MMR6:
|
||
|
case Mips::RECIP_S_MMR6:
|
||
|
case Mips::ROUND_L_D_MMR6:
|
||
|
case Mips::ROUND_L_S_MMR6:
|
||
|
case Mips::ROUND_W_D_MMR6:
|
||
|
case Mips::ROUND_W_S_MMR6:
|
||
|
case Mips::RSQRT_D_MMR6:
|
||
|
case Mips::RSQRT_S_MMR6:
|
||
|
case Mips::SQRT_D_MMR6:
|
||
|
case Mips::SQRT_S_MMR6:
|
||
|
case Mips::TRUNC_L_D_MMR6:
|
||
|
case Mips::TRUNC_L_S_MMR6:
|
||
|
case Mips::TRUNC_W_D_MMR6:
|
||
|
case Mips::TRUNC_W_S_MMR6: {
|
||
|
// op: ft
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::FADD_D_MMR6:
|
||
|
case Mips::FADD_S_MMR6:
|
||
|
case Mips::FDIV_D_MMR6:
|
||
|
case Mips::FDIV_S_MMR6:
|
||
|
case Mips::FMUL_D_MMR6:
|
||
|
case Mips::FMUL_S_MMR6:
|
||
|
case Mips::FSUB_D_MMR6:
|
||
|
case Mips::FSUB_S_MMR6: {
|
||
|
// op: ft
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: fd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MAXA_D:
|
||
|
case Mips::MAXA_S:
|
||
|
case Mips::MAX_D:
|
||
|
case Mips::MAX_S:
|
||
|
case Mips::MINA_D:
|
||
|
case Mips::MINA_S:
|
||
|
case Mips::MIN_D:
|
||
|
case Mips::MIN_S:
|
||
|
case Mips::SELEQZ_D:
|
||
|
case Mips::SELEQZ_S:
|
||
|
case Mips::SELNEZ_D:
|
||
|
case Mips::SELNEZ_S: {
|
||
|
// op: ft
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: fd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CMP_AF_D_MMR6:
|
||
|
case Mips::CMP_AF_S_MMR6:
|
||
|
case Mips::CMP_EQ_D_MMR6:
|
||
|
case Mips::CMP_EQ_S_MMR6:
|
||
|
case Mips::CMP_LE_D_MMR6:
|
||
|
case Mips::CMP_LE_S_MMR6:
|
||
|
case Mips::CMP_LT_D_MMR6:
|
||
|
case Mips::CMP_LT_S_MMR6:
|
||
|
case Mips::CMP_SAF_D_MMR6:
|
||
|
case Mips::CMP_SAF_S_MMR6:
|
||
|
case Mips::CMP_SEQ_D_MMR6:
|
||
|
case Mips::CMP_SEQ_S_MMR6:
|
||
|
case Mips::CMP_SLE_D_MMR6:
|
||
|
case Mips::CMP_SLE_S_MMR6:
|
||
|
case Mips::CMP_SLT_D_MMR6:
|
||
|
case Mips::CMP_SLT_S_MMR6:
|
||
|
case Mips::CMP_SUEQ_D_MMR6:
|
||
|
case Mips::CMP_SUEQ_S_MMR6:
|
||
|
case Mips::CMP_SULE_D_MMR6:
|
||
|
case Mips::CMP_SULE_S_MMR6:
|
||
|
case Mips::CMP_SULT_D_MMR6:
|
||
|
case Mips::CMP_SULT_S_MMR6:
|
||
|
case Mips::CMP_SUN_D_MMR6:
|
||
|
case Mips::CMP_SUN_S_MMR6:
|
||
|
case Mips::CMP_UEQ_D_MMR6:
|
||
|
case Mips::CMP_UEQ_S_MMR6:
|
||
|
case Mips::CMP_ULE_D_MMR6:
|
||
|
case Mips::CMP_ULE_S_MMR6:
|
||
|
case Mips::CMP_ULT_D_MMR6:
|
||
|
case Mips::CMP_ULT_S_MMR6:
|
||
|
case Mips::CMP_UN_D_MMR6:
|
||
|
case Mips::CMP_UN_S_MMR6:
|
||
|
case Mips::FADD_MM:
|
||
|
case Mips::FADD_S_MM:
|
||
|
case Mips::FDIV_MM:
|
||
|
case Mips::FDIV_S_MM:
|
||
|
case Mips::FMUL_MM:
|
||
|
case Mips::FMUL_S_MM:
|
||
|
case Mips::FSUB_MM:
|
||
|
case Mips::FSUB_S_MM:
|
||
|
case Mips::MAXA_D_MMR6:
|
||
|
case Mips::MAXA_S_MMR6:
|
||
|
case Mips::MAX_D_MMR6:
|
||
|
case Mips::MAX_S_MMR6:
|
||
|
case Mips::MINA_D_MMR6:
|
||
|
case Mips::MINA_S_MMR6:
|
||
|
case Mips::MIN_D_MMR6:
|
||
|
case Mips::MIN_S_MMR6:
|
||
|
case Mips::SELENZ_D_MMR6:
|
||
|
case Mips::SELENZ_S_MMR6:
|
||
|
case Mips::SELEQZ_D_MMR6:
|
||
|
case Mips::SELEQZ_S_MMR6: {
|
||
|
// op: ft
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: fd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MADDF_D:
|
||
|
case Mips::MADDF_S:
|
||
|
case Mips::MSUBF_D:
|
||
|
case Mips::MSUBF_S:
|
||
|
case Mips::SEL_D:
|
||
|
case Mips::SEL_S: {
|
||
|
// op: ft
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: fd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MADDF_D_MMR6:
|
||
|
case Mips::MADDF_S_MMR6:
|
||
|
case Mips::MSUBF_D_MMR6:
|
||
|
case Mips::MSUBF_S_MMR6:
|
||
|
case Mips::SEL_D_MMR6:
|
||
|
case Mips::SEL_S_MMR6: {
|
||
|
// op: ft
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: fd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MADD_D32_MM:
|
||
|
case Mips::MADD_S_MM:
|
||
|
case Mips::MSUB_D32_MM:
|
||
|
case Mips::MSUB_S_MM:
|
||
|
case Mips::NMADD_D32_MM:
|
||
|
case Mips::NMADD_S_MM:
|
||
|
case Mips::NMSUB_D32_MM:
|
||
|
case Mips::NMSUB_S_MM: {
|
||
|
// op: ft
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: fd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: fr
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADDVI_B:
|
||
|
case Mips::ADDVI_D:
|
||
|
case Mips::ADDVI_H:
|
||
|
case Mips::ADDVI_W:
|
||
|
case Mips::CEQI_B:
|
||
|
case Mips::CEQI_D:
|
||
|
case Mips::CEQI_H:
|
||
|
case Mips::CEQI_W:
|
||
|
case Mips::CLEI_S_B:
|
||
|
case Mips::CLEI_S_D:
|
||
|
case Mips::CLEI_S_H:
|
||
|
case Mips::CLEI_S_W:
|
||
|
case Mips::CLEI_U_B:
|
||
|
case Mips::CLEI_U_D:
|
||
|
case Mips::CLEI_U_H:
|
||
|
case Mips::CLEI_U_W:
|
||
|
case Mips::CLTI_S_B:
|
||
|
case Mips::CLTI_S_D:
|
||
|
case Mips::CLTI_S_H:
|
||
|
case Mips::CLTI_S_W:
|
||
|
case Mips::CLTI_U_B:
|
||
|
case Mips::CLTI_U_D:
|
||
|
case Mips::CLTI_U_H:
|
||
|
case Mips::CLTI_U_W:
|
||
|
case Mips::MAXI_S_B:
|
||
|
case Mips::MAXI_S_D:
|
||
|
case Mips::MAXI_S_H:
|
||
|
case Mips::MAXI_S_W:
|
||
|
case Mips::MAXI_U_B:
|
||
|
case Mips::MAXI_U_D:
|
||
|
case Mips::MAXI_U_H:
|
||
|
case Mips::MAXI_U_W:
|
||
|
case Mips::MINI_S_B:
|
||
|
case Mips::MINI_S_D:
|
||
|
case Mips::MINI_S_H:
|
||
|
case Mips::MINI_S_W:
|
||
|
case Mips::MINI_U_B:
|
||
|
case Mips::MINI_U_D:
|
||
|
case Mips::MINI_U_H:
|
||
|
case Mips::MINI_U_W:
|
||
|
case Mips::SUBVI_B:
|
||
|
case Mips::SUBVI_D:
|
||
|
case Mips::SUBVI_H:
|
||
|
case Mips::SUBVI_W: {
|
||
|
// op: imm
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADDIUSP_MM: {
|
||
|
// op: imm
|
||
|
op = getSImm9AddiuspValue(MI, 0, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(511)) << 1;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::JRCADDIUSP_MMR6: {
|
||
|
// op: imm
|
||
|
op = getUImm5Lsl2Encoding(MI, 0, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 5;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::JRADDIUSP: {
|
||
|
// op: imm
|
||
|
op = getUImm5Lsl2Encoding(MI, 0, Fixups, STI);
|
||
|
Value |= op & UINT64_C(31);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::Bimm16: {
|
||
|
// op: imm11
|
||
|
op = getBranchTargetOpValue(MI, 0, Fixups, STI);
|
||
|
Value |= op & UINT64_C(2047);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::AddiuRxRyOffMemX16: {
|
||
|
// op: imm15
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(2032)) << 16;
|
||
|
Value |= (op & UINT64_C(30720)) << 5;
|
||
|
Value |= op & UINT64_C(15);
|
||
|
// op: rx
|
||
|
op = getMemEncoding(MI, 1, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 8;
|
||
|
// op: ry
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 5;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BimmX16: {
|
||
|
// op: imm16
|
||
|
op = getBranchTargetOpValue(MI, 0, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(2016)) << 16;
|
||
|
Value |= (op & UINT64_C(63488)) << 5;
|
||
|
Value |= op & UINT64_C(31);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::AddiuSpImmX16:
|
||
|
case Mips::BteqzX16:
|
||
|
case Mips::BtnezX16: {
|
||
|
// op: imm16
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(2016)) << 16;
|
||
|
Value |= (op & UINT64_C(63488)) << 5;
|
||
|
Value |= op & UINT64_C(31);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::AddiuRxImmX16:
|
||
|
case Mips::AddiuRxPcImmX16:
|
||
|
case Mips::AddiuRxRxImmX16:
|
||
|
case Mips::BeqzRxImmX16:
|
||
|
case Mips::BnezRxImmX16:
|
||
|
case Mips::CmpiRxImmX16:
|
||
|
case Mips::LiRxImmAlignX16:
|
||
|
case Mips::LiRxImmX16:
|
||
|
case Mips::LwRxPcTcpX16:
|
||
|
case Mips::LwRxSpImmX16:
|
||
|
case Mips::SltiRxImmX16:
|
||
|
case Mips::SltiuRxImmX16:
|
||
|
case Mips::SwRxSpImmX16: {
|
||
|
// op: imm16
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(2016)) << 16;
|
||
|
Value |= (op & UINT64_C(63488)) << 5;
|
||
|
Value |= op & UINT64_C(31);
|
||
|
// op: rx
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 8;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LbRxRyOffMemX16:
|
||
|
case Mips::LbuRxRyOffMemX16:
|
||
|
case Mips::LhRxRyOffMemX16:
|
||
|
case Mips::LhuRxRyOffMemX16:
|
||
|
case Mips::LwRxRyOffMemX16:
|
||
|
case Mips::SbRxRyOffMemX16:
|
||
|
case Mips::ShRxRyOffMemX16:
|
||
|
case Mips::SwRxRyOffMemX16: {
|
||
|
// op: imm16
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(2016)) << 16;
|
||
|
Value |= (op & UINT64_C(63488)) << 5;
|
||
|
Value |= op & UINT64_C(31);
|
||
|
// op: rx
|
||
|
op = getMemEncoding(MI, 1, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 8;
|
||
|
// op: ry
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 5;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::Jal16:
|
||
|
case Mips::JalB16: {
|
||
|
// op: imm26
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(2031616)) << 5;
|
||
|
Value |= (op & UINT64_C(65011712)) >> 5;
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::AddiuSpImm16:
|
||
|
case Mips::Bteqz16:
|
||
|
case Mips::Btnez16: {
|
||
|
// op: imm8
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= op & UINT64_C(255);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::PREFX_MM: {
|
||
|
// op: index
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: base
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: hint
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LBUX_MM:
|
||
|
case Mips::LHX_MM:
|
||
|
case Mips::LWX_MM: {
|
||
|
// op: index
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: base
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::COPY_S_D: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(1)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SPLATI_D: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(1)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::INSVE_D: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(1)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::COPY_S_B:
|
||
|
case Mips::COPY_U_B: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(15)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SPLATI_B: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(15)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::INSVE_B: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(15)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::COPY_S_W:
|
||
|
case Mips::COPY_U_W: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SPLATI_W: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::INSVE_W: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::COPY_S_H:
|
||
|
case Mips::COPY_U_H: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SPLATI_H: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::INSVE_H: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::INSERT_D: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(1)) << 16;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SLDI_D: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(1)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::INSERT_B: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(15)) << 16;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SLDI_B: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(15)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::INSERT_W: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 16;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SLDI_W: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::INSERT_H: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 16;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SLDI_H: {
|
||
|
// op: n
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BALC:
|
||
|
case Mips::BC: {
|
||
|
// op: offset
|
||
|
op = getBranchTarget26OpValue(MI, 0, Fixups, STI);
|
||
|
Value |= op & UINT64_C(67108863);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BALC_MMR6:
|
||
|
case Mips::BC_MMR6: {
|
||
|
// op: offset
|
||
|
op = getBranchTarget26OpValueMM(MI, 0, Fixups, STI);
|
||
|
Value |= op & UINT64_C(67108863);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BAL:
|
||
|
case Mips::BPOSGE32: {
|
||
|
// op: offset
|
||
|
op = getBranchTargetOpValue(MI, 0, Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BNZ_B:
|
||
|
case Mips::BNZ_D:
|
||
|
case Mips::BNZ_H:
|
||
|
case Mips::BNZ_V:
|
||
|
case Mips::BNZ_W:
|
||
|
case Mips::BZ_B:
|
||
|
case Mips::BZ_D:
|
||
|
case Mips::BZ_H:
|
||
|
case Mips::BZ_V:
|
||
|
case Mips::BZ_W: {
|
||
|
// op: offset
|
||
|
op = getBranchTargetOpValue(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
// op: wt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BC1F_MM:
|
||
|
case Mips::BC1T_MM: {
|
||
|
// op: offset
|
||
|
op = getBranchTargetOpValueMM(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::B16_MM:
|
||
|
case Mips::BC16_MMR6: {
|
||
|
// op: offset
|
||
|
op = getBranchTargetOpValueMMPC10(MI, 0, Fixups, STI);
|
||
|
Value |= op & UINT64_C(1023);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::Move32R16: {
|
||
|
// op: r32
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 5;
|
||
|
Value |= op & UINT64_C(24);
|
||
|
// op: rz
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= op & UINT64_C(7);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MFHI:
|
||
|
case Mips::MFHI64:
|
||
|
case Mips::MFLO:
|
||
|
case Mips::MFLO64: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MFHI_DSP:
|
||
|
case Mips::MFLO_DSP: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: ac
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LWXS_MM: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: base
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: index
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LBUX:
|
||
|
case Mips::LHX:
|
||
|
case Mips::LWX: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: base
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: index
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::REPL_PH:
|
||
|
case Mips::REPL_PH_MM:
|
||
|
case Mips::REPL_QB: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: imm
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(1023)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::RDDSP: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: mask
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(1023)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADDQH_PH_MMR2:
|
||
|
case Mips::ADDQH_R_PH_MMR2:
|
||
|
case Mips::ADDQH_R_W_MMR2:
|
||
|
case Mips::ADDQH_W_MMR2:
|
||
|
case Mips::ADDQ_PH_MM:
|
||
|
case Mips::ADDQ_S_PH_MM:
|
||
|
case Mips::ADDQ_S_W_MM:
|
||
|
case Mips::ADDSC_MM:
|
||
|
case Mips::ADDUH_QB_MMR2:
|
||
|
case Mips::ADDUH_R_QB_MMR2:
|
||
|
case Mips::ADDU_PH_MMR2:
|
||
|
case Mips::ADDU_QB_MM:
|
||
|
case Mips::ADDU_S_PH_MMR2:
|
||
|
case Mips::ADDU_S_QB_MM:
|
||
|
case Mips::ADDWC_MM:
|
||
|
case Mips::MULEQ_S_W_PHL_MM:
|
||
|
case Mips::MULEQ_S_W_PHR_MM:
|
||
|
case Mips::MULEU_S_PH_QBL_MM:
|
||
|
case Mips::MULEU_S_PH_QBR_MM:
|
||
|
case Mips::MULQ_RS_PH_MM:
|
||
|
case Mips::MULQ_RS_W_MMR2:
|
||
|
case Mips::MULQ_S_PH_MMR2:
|
||
|
case Mips::MULQ_S_W_MMR2:
|
||
|
case Mips::MUL_PH_MMR2:
|
||
|
case Mips::MUL_S_PH_MMR2:
|
||
|
case Mips::PACKRL_PH_MM:
|
||
|
case Mips::PICK_PH_MM:
|
||
|
case Mips::PICK_QB_MM:
|
||
|
case Mips::PRECRQU_S_QB_PH_MM:
|
||
|
case Mips::PRECRQ_PH_W_MM:
|
||
|
case Mips::PRECRQ_QB_PH_MM:
|
||
|
case Mips::PRECRQ_RS_PH_W_MM:
|
||
|
case Mips::PRECR_QB_PH_MMR2:
|
||
|
case Mips::SELEQZ_MMR6:
|
||
|
case Mips::SELNEZ_MMR6:
|
||
|
case Mips::SUBQH_PH_MMR2:
|
||
|
case Mips::SUBQH_R_PH_MMR2:
|
||
|
case Mips::SUBQH_R_W_MMR2:
|
||
|
case Mips::SUBQH_W_MMR2:
|
||
|
case Mips::SUBQ_PH_MM:
|
||
|
case Mips::SUBQ_S_PH_MM:
|
||
|
case Mips::SUBQ_S_W_MM:
|
||
|
case Mips::SUBUH_QB_MMR2:
|
||
|
case Mips::SUBUH_R_QB_MMR2:
|
||
|
case Mips::SUBU_PH_MMR2:
|
||
|
case Mips::SUBU_QB_MM:
|
||
|
case Mips::SUBU_S_PH_MMR2:
|
||
|
case Mips::SUBU_S_QB_MM: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LSA_MMR6: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: imm2
|
||
|
op = getUImmWithOffsetEncoding<2, 1>(MI, 3, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 9;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CLO_R6:
|
||
|
case Mips::CLZ_R6:
|
||
|
case Mips::DCLO_R6:
|
||
|
case Mips::DCLZ_R6:
|
||
|
case Mips::DPOP:
|
||
|
case Mips::JALR:
|
||
|
case Mips::JALR64:
|
||
|
case Mips::JALR_HB:
|
||
|
case Mips::POP:
|
||
|
case Mips::RADDU_W_QB: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MOVF_I:
|
||
|
case Mips::MOVF_I64:
|
||
|
case Mips::MOVT_I:
|
||
|
case Mips::MOVT_I64: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: fcc
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 18;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADD:
|
||
|
case Mips::ADDQH_PH:
|
||
|
case Mips::ADDQH_R_PH:
|
||
|
case Mips::ADDQH_R_W:
|
||
|
case Mips::ADDQH_W:
|
||
|
case Mips::ADDQ_PH:
|
||
|
case Mips::ADDQ_S_PH:
|
||
|
case Mips::ADDQ_S_W:
|
||
|
case Mips::ADDSC:
|
||
|
case Mips::ADDUH_QB:
|
||
|
case Mips::ADDUH_R_QB:
|
||
|
case Mips::ADDU_PH:
|
||
|
case Mips::ADDU_QB:
|
||
|
case Mips::ADDU_S_PH:
|
||
|
case Mips::ADDU_S_QB:
|
||
|
case Mips::ADDWC:
|
||
|
case Mips::ADDu:
|
||
|
case Mips::AND:
|
||
|
case Mips::AND64:
|
||
|
case Mips::BADDu:
|
||
|
case Mips::DADD:
|
||
|
case Mips::DADDu:
|
||
|
case Mips::DDIV:
|
||
|
case Mips::DDIVU:
|
||
|
case Mips::DIV:
|
||
|
case Mips::DIVU:
|
||
|
case Mips::DMOD:
|
||
|
case Mips::DMODU:
|
||
|
case Mips::DMUH:
|
||
|
case Mips::DMUHU:
|
||
|
case Mips::DMUL:
|
||
|
case Mips::DMULU:
|
||
|
case Mips::DMUL_R6:
|
||
|
case Mips::DSUB:
|
||
|
case Mips::DSUBu:
|
||
|
case Mips::MOD:
|
||
|
case Mips::MODSUB:
|
||
|
case Mips::MODU:
|
||
|
case Mips::MOVN_I64_I:
|
||
|
case Mips::MOVN_I64_I64:
|
||
|
case Mips::MOVN_I_I:
|
||
|
case Mips::MOVN_I_I64:
|
||
|
case Mips::MOVZ_I64_I:
|
||
|
case Mips::MOVZ_I64_I64:
|
||
|
case Mips::MOVZ_I_I:
|
||
|
case Mips::MOVZ_I_I64:
|
||
|
case Mips::MUH:
|
||
|
case Mips::MUHU:
|
||
|
case Mips::MUL:
|
||
|
case Mips::MULEQ_S_W_PHL:
|
||
|
case Mips::MULEQ_S_W_PHR:
|
||
|
case Mips::MULEU_S_PH_QBL:
|
||
|
case Mips::MULEU_S_PH_QBR:
|
||
|
case Mips::MULQ_RS_PH:
|
||
|
case Mips::MULQ_RS_W:
|
||
|
case Mips::MULQ_S_PH:
|
||
|
case Mips::MULQ_S_W:
|
||
|
case Mips::MULU:
|
||
|
case Mips::MUL_PH:
|
||
|
case Mips::MUL_R6:
|
||
|
case Mips::MUL_S_PH:
|
||
|
case Mips::NOR:
|
||
|
case Mips::NOR64:
|
||
|
case Mips::OR:
|
||
|
case Mips::OR64:
|
||
|
case Mips::SELEQZ:
|
||
|
case Mips::SELEQZ64:
|
||
|
case Mips::SELNEZ:
|
||
|
case Mips::SELNEZ64:
|
||
|
case Mips::SEQ:
|
||
|
case Mips::SLT:
|
||
|
case Mips::SLT64:
|
||
|
case Mips::SLTu:
|
||
|
case Mips::SLTu64:
|
||
|
case Mips::SNE:
|
||
|
case Mips::SUB:
|
||
|
case Mips::SUBQH_PH:
|
||
|
case Mips::SUBQH_R_PH:
|
||
|
case Mips::SUBQH_R_W:
|
||
|
case Mips::SUBQH_W:
|
||
|
case Mips::SUBQ_PH:
|
||
|
case Mips::SUBQ_S_PH:
|
||
|
case Mips::SUBQ_S_W:
|
||
|
case Mips::SUBUH_QB:
|
||
|
case Mips::SUBUH_R_QB:
|
||
|
case Mips::SUBU_PH:
|
||
|
case Mips::SUBU_QB:
|
||
|
case Mips::SUBU_S_PH:
|
||
|
case Mips::SUBU_S_QB:
|
||
|
case Mips::SUBu:
|
||
|
case Mips::V3MULU:
|
||
|
case Mips::VMM0:
|
||
|
case Mips::VMULU:
|
||
|
case Mips::XOR:
|
||
|
case Mips::XOR64: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ALIGN: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: bp
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ALIGN_MMR6: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: bp
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 9;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DALIGN: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: bp
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DLSA_R6:
|
||
|
case Mips::LSA_R6: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: imm2
|
||
|
op = getUImmWithOffsetEncoding<2, 1>(MI, 3, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SHLLV_PH_MM:
|
||
|
case Mips::SHLLV_QB_MM:
|
||
|
case Mips::SHLLV_S_PH_MM:
|
||
|
case Mips::SHLLV_S_W_MM:
|
||
|
case Mips::SHRAV_PH_MM:
|
||
|
case Mips::SHRAV_QB_MMR2:
|
||
|
case Mips::SHRAV_R_PH_MM:
|
||
|
case Mips::SHRAV_R_QB_MMR2:
|
||
|
case Mips::SHRAV_R_W_MM:
|
||
|
case Mips::SHRLV_PH_MMR2:
|
||
|
case Mips::SHRLV_QB_MM: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ABSQ_S_PH:
|
||
|
case Mips::ABSQ_S_QB:
|
||
|
case Mips::ABSQ_S_W:
|
||
|
case Mips::BITREV:
|
||
|
case Mips::BITSWAP:
|
||
|
case Mips::DBITSWAP:
|
||
|
case Mips::DSBH:
|
||
|
case Mips::DSHD:
|
||
|
case Mips::DSLL64_32:
|
||
|
case Mips::PRECEQU_PH_QBL:
|
||
|
case Mips::PRECEQU_PH_QBLA:
|
||
|
case Mips::PRECEQU_PH_QBR:
|
||
|
case Mips::PRECEQU_PH_QBRA:
|
||
|
case Mips::PRECEQ_W_PHL:
|
||
|
case Mips::PRECEQ_W_PHR:
|
||
|
case Mips::PRECEU_PH_QBL:
|
||
|
case Mips::PRECEU_PH_QBLA:
|
||
|
case Mips::PRECEU_PH_QBR:
|
||
|
case Mips::PRECEU_PH_QBRA:
|
||
|
case Mips::REPLV_PH:
|
||
|
case Mips::REPLV_QB:
|
||
|
case Mips::SEB:
|
||
|
case Mips::SEB64:
|
||
|
case Mips::SEH:
|
||
|
case Mips::SEH64:
|
||
|
case Mips::SLL64_32:
|
||
|
case Mips::SLL64_64:
|
||
|
case Mips::WSBH: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DROTRV:
|
||
|
case Mips::DSLLV:
|
||
|
case Mips::DSRAV:
|
||
|
case Mips::DSRLV:
|
||
|
case Mips::ROTRV:
|
||
|
case Mips::SLLV:
|
||
|
case Mips::SRAV:
|
||
|
case Mips::SRLV: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SHLLV_PH:
|
||
|
case Mips::SHLLV_QB:
|
||
|
case Mips::SHLLV_S_PH:
|
||
|
case Mips::SHLLV_S_W:
|
||
|
case Mips::SHLL_PH:
|
||
|
case Mips::SHLL_QB:
|
||
|
case Mips::SHLL_S_PH:
|
||
|
case Mips::SHLL_S_W:
|
||
|
case Mips::SHRAV_PH:
|
||
|
case Mips::SHRAV_QB:
|
||
|
case Mips::SHRAV_R_PH:
|
||
|
case Mips::SHRAV_R_QB:
|
||
|
case Mips::SHRAV_R_W:
|
||
|
case Mips::SHRA_PH:
|
||
|
case Mips::SHRA_QB:
|
||
|
case Mips::SHRA_R_PH:
|
||
|
case Mips::SHRA_R_QB:
|
||
|
case Mips::SHRA_R_W:
|
||
|
case Mips::SHRLV_PH:
|
||
|
case Mips::SHRLV_QB:
|
||
|
case Mips::SHRL_PH:
|
||
|
case Mips::SHRL_QB: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rs_sa
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DROTR:
|
||
|
case Mips::DROTR32:
|
||
|
case Mips::DSLL:
|
||
|
case Mips::DSLL32:
|
||
|
case Mips::DSRA:
|
||
|
case Mips::DSRA32:
|
||
|
case Mips::DSRL:
|
||
|
case Mips::DSRL32:
|
||
|
case Mips::ROTR:
|
||
|
case Mips::SLL:
|
||
|
case Mips::SRA:
|
||
|
case Mips::SRL: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: shamt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ROTRV_MM:
|
||
|
case Mips::SLLV_MM:
|
||
|
case Mips::SRAV_MM:
|
||
|
case Mips::SRLV_MM: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADDU_MMR6:
|
||
|
case Mips::ADD_MMR6:
|
||
|
case Mips::AND_MMR6:
|
||
|
case Mips::DIVU_MMR6:
|
||
|
case Mips::DIV_MMR6:
|
||
|
case Mips::MODU_MMR6:
|
||
|
case Mips::MOD_MMR6:
|
||
|
case Mips::MUHU_MMR6:
|
||
|
case Mips::MUH_MMR6:
|
||
|
case Mips::MULU_MMR6:
|
||
|
case Mips::MUL_MMR6:
|
||
|
case Mips::NOR_MMR6:
|
||
|
case Mips::OR_MMR6:
|
||
|
case Mips::SUBU_MMR6:
|
||
|
case Mips::SUB_MMR6:
|
||
|
case Mips::XOR_MMR6: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MFHI_MM:
|
||
|
case Mips::MFLO_MM: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BITSWAP_MMR6: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CLO:
|
||
|
case Mips::CLZ:
|
||
|
case Mips::DCLO:
|
||
|
case Mips::DCLZ: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CLO_MM:
|
||
|
case Mips::CLZ_MM: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MOVF_I_MM:
|
||
|
case Mips::MOVT_I_MM: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: fcc
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 13;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DDIVU_MM64R6:
|
||
|
case Mips::DDIV_MM64R6:
|
||
|
case Mips::DMODU_MM64R6:
|
||
|
case Mips::DMOD_MM64R6: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SEB_MM:
|
||
|
case Mips::SEB_MMR6:
|
||
|
case Mips::SEH_MM:
|
||
|
case Mips::SEH_MMR6:
|
||
|
case Mips::WSBH_MM: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ROTR_MM:
|
||
|
case Mips::SLL_MM:
|
||
|
case Mips::SLL_MMR6:
|
||
|
case Mips::SRA_MM:
|
||
|
case Mips::SRL_MM: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: shamt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CFCMSA: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: cs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LI16_MM:
|
||
|
case Mips::LI16_MMR6: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 7;
|
||
|
// op: imm
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= op & UINT64_C(127);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADDIUR1SP_MM: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 7;
|
||
|
// op: imm
|
||
|
op = getUImm6Lsl2Encoding(MI, 1, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(63)) << 1;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADDIUR2_MM: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 7;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 4;
|
||
|
// op: imm
|
||
|
op = getSImm3Lsa2Value(MI, 2, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 1;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ANDI16_MM:
|
||
|
case Mips::ANDI16_MMR6: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 7;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 4;
|
||
|
// op: imm
|
||
|
op = getUImm4AndValue(MI, 2, Fixups, STI);
|
||
|
Value |= op & UINT64_C(15);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SLL16_MM:
|
||
|
case Mips::SLL16_MMR6:
|
||
|
case Mips::SRL16_MM:
|
||
|
case Mips::SRL16_MMR6: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 7;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 4;
|
||
|
// op: shamt
|
||
|
op = getUImm3Mod8Encoding(MI, 2, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 1;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADDU16_MM:
|
||
|
case Mips::SUBU16_MM: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 7;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 4;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 1;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MFHI16_MM:
|
||
|
case Mips::MFLO16_MM: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= op & UINT64_C(31);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADDIUS5_MM: {
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 5;
|
||
|
// op: imm
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(15)) << 1;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::JR_MM:
|
||
|
case Mips::MTHI_MM:
|
||
|
case Mips::MTLO_MM: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MFHI_DSP_MM:
|
||
|
case Mips::MFLO_DSP_MM: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: ac
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 14;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DAHI_MM64R6:
|
||
|
case Mips::DATI_MM64R6: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: imm
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::TEQI_MM:
|
||
|
case Mips::TGEIU_MM:
|
||
|
case Mips::TGEI_MM:
|
||
|
case Mips::TLTIU_MM:
|
||
|
case Mips::TLTI_MM:
|
||
|
case Mips::TNEI_MM: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: imm16
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BEQZC_MM:
|
||
|
case Mips::BGEZALS_MM:
|
||
|
case Mips::BGEZAL_MM:
|
||
|
case Mips::BGEZ_MM:
|
||
|
case Mips::BGTZ_MM:
|
||
|
case Mips::BLEZ_MM:
|
||
|
case Mips::BLTZALS_MM:
|
||
|
case Mips::BLTZAL_MM:
|
||
|
case Mips::BLTZ_MM:
|
||
|
case Mips::BNEZC_MM: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: offset
|
||
|
op = getBranchTargetOpValueMM(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MADDU_MM:
|
||
|
case Mips::MADD_MM:
|
||
|
case Mips::MSUBU_MM:
|
||
|
case Mips::MSUB_MM:
|
||
|
case Mips::MULT_MM:
|
||
|
case Mips::MULTu_MM:
|
||
|
case Mips::SDIV_MM:
|
||
|
case Mips::UDIV_MM: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::TEQ_MM:
|
||
|
case Mips::TGEU_MM:
|
||
|
case Mips::TGE_MM:
|
||
|
case Mips::TLTU_MM:
|
||
|
case Mips::TLT_MM:
|
||
|
case Mips::TNE_MM: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: code_
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(15)) << 12;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BEQ_MM:
|
||
|
case Mips::BNE_MM: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: offset
|
||
|
op = getBranchTargetOpValueMM(MI, 2, Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::JR:
|
||
|
case Mips::JR64:
|
||
|
case Mips::JR_HB:
|
||
|
case Mips::JR_HB_R6:
|
||
|
case Mips::MTHI:
|
||
|
case Mips::MTHI64:
|
||
|
case Mips::MTLO:
|
||
|
case Mips::MTLO64:
|
||
|
case Mips::MTM0:
|
||
|
case Mips::MTM1:
|
||
|
case Mips::MTM2:
|
||
|
case Mips::MTP0:
|
||
|
case Mips::MTP1:
|
||
|
case Mips::MTP2: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ALUIPC:
|
||
|
case Mips::AUIPC: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: imm
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DAHI:
|
||
|
case Mips::DATI: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: imm
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LDPC: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: imm
|
||
|
op = getSimm18Lsl3Encoding(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(262143);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADDIUPC:
|
||
|
case Mips::LWPC:
|
||
|
case Mips::LWUPC: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: imm
|
||
|
op = getSimm19Lsl2Encoding(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(524287);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::TEQI:
|
||
|
case Mips::TGEI:
|
||
|
case Mips::TGEIU:
|
||
|
case Mips::TLTI:
|
||
|
case Mips::TNEI:
|
||
|
case Mips::TTLTIU: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: imm16
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::WRDSP: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: mask
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(1023)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BEQZC:
|
||
|
case Mips::BNEZC: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: offset
|
||
|
op = getBranchTarget21OpValue(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(2097151);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BGEZ:
|
||
|
case Mips::BGEZ64:
|
||
|
case Mips::BGEZAL:
|
||
|
case Mips::BGEZALL:
|
||
|
case Mips::BGEZL:
|
||
|
case Mips::BGTZ:
|
||
|
case Mips::BGTZ64:
|
||
|
case Mips::BGTZL:
|
||
|
case Mips::BLEZ:
|
||
|
case Mips::BLEZ64:
|
||
|
case Mips::BLEZL:
|
||
|
case Mips::BLTZ:
|
||
|
case Mips::BLTZ64:
|
||
|
case Mips::BLTZAL:
|
||
|
case Mips::BLTZALL:
|
||
|
case Mips::BLTZL: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: offset
|
||
|
op = getBranchTargetOpValue(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BBIT0:
|
||
|
case Mips::BBIT032:
|
||
|
case Mips::BBIT1:
|
||
|
case Mips::BBIT132: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: p
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: offset
|
||
|
op = getBranchTargetOpValue(MI, 2, Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CMPU_EQ_QB:
|
||
|
case Mips::CMPU_LE_QB:
|
||
|
case Mips::CMPU_LT_QB:
|
||
|
case Mips::CMP_EQ_PH:
|
||
|
case Mips::CMP_LE_PH:
|
||
|
case Mips::CMP_LT_PH:
|
||
|
case Mips::DMULT:
|
||
|
case Mips::DMULTu:
|
||
|
case Mips::DSDIV:
|
||
|
case Mips::DUDIV:
|
||
|
case Mips::MADD:
|
||
|
case Mips::MADDU:
|
||
|
case Mips::MSUB:
|
||
|
case Mips::MSUBU:
|
||
|
case Mips::MULT:
|
||
|
case Mips::MULTu:
|
||
|
case Mips::SDIV:
|
||
|
case Mips::UDIV: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::TEQ:
|
||
|
case Mips::TGE:
|
||
|
case Mips::TGEU:
|
||
|
case Mips::TLT:
|
||
|
case Mips::TLTU:
|
||
|
case Mips::TNE: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: code_
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(1023)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::AUI:
|
||
|
case Mips::DAUI: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: imm
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BEQ:
|
||
|
case Mips::BEQ64:
|
||
|
case Mips::BEQC:
|
||
|
case Mips::BEQL:
|
||
|
case Mips::BGEC:
|
||
|
case Mips::BGEUC:
|
||
|
case Mips::BLTC:
|
||
|
case Mips::BLTUC:
|
||
|
case Mips::BNE:
|
||
|
case Mips::BNE64:
|
||
|
case Mips::BNEC:
|
||
|
case Mips::BNEL:
|
||
|
case Mips::BNVC:
|
||
|
case Mips::BOVC: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: offset
|
||
|
op = getBranchTargetOpValue(MI, 2, Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::JALRC16_MMR6:
|
||
|
case Mips::JRC16_MMR6: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 5;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADDIUPC_MM: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 23;
|
||
|
// op: imm
|
||
|
op = getSimm23Lsl2Encoding(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(8388607);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BEQZ16_MM:
|
||
|
case Mips::BEQZC16_MMR6:
|
||
|
case Mips::BNEZ16_MM:
|
||
|
case Mips::BNEZC16_MMR6: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 7;
|
||
|
// op: offset
|
||
|
op = getBranchTarget7OpValueMM(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(127);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::JALR16_MM:
|
||
|
case Mips::JALRS16_MM:
|
||
|
case Mips::JR16_MM:
|
||
|
case Mips::JRC16_MM: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= op & UINT64_C(31);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CTCMSA: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: cd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::FILL_B:
|
||
|
case Mips::FILL_D:
|
||
|
case Mips::FILL_H:
|
||
|
case Mips::FILL_W: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MTHI_DSP_MM:
|
||
|
case Mips::MTHLIP_MM:
|
||
|
case Mips::MTLO_DSP_MM:
|
||
|
case Mips::SHILOV_MM: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: ac
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 14;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::JALRS_MM:
|
||
|
case Mips::JALR_MM: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CLO_MMR6: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::AUI_MMR6: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: imm
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADDi_MM:
|
||
|
case Mips::ADDiu_MM:
|
||
|
case Mips::ANDi_MM:
|
||
|
case Mips::ORi_MM:
|
||
|
case Mips::XORi_MM: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: imm16
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MTHI_DSP:
|
||
|
case Mips::MTLO_DSP: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: ac
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CLZ_MMR6: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SEQi:
|
||
|
case Mips::SNEi: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: imm10
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(1023)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADDi:
|
||
|
case Mips::ADDiu:
|
||
|
case Mips::ANDi:
|
||
|
case Mips::ANDi64:
|
||
|
case Mips::DADDi:
|
||
|
case Mips::DADDiu:
|
||
|
case Mips::ORi:
|
||
|
case Mips::ORi64:
|
||
|
case Mips::XORi:
|
||
|
case Mips::XORi64: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: imm16
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::PRECR_SRA_PH_W:
|
||
|
case Mips::PRECR_SRA_R_PH_W: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: sa
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CMPGDU_EQ_QB:
|
||
|
case Mips::CMPGDU_LE_QB:
|
||
|
case Mips::CMPGDU_LT_QB:
|
||
|
case Mips::CMPGU_EQ_QB:
|
||
|
case Mips::CMPGU_LE_QB:
|
||
|
case Mips::CMPGU_LT_QB:
|
||
|
case Mips::PACKRL_PH:
|
||
|
case Mips::PICK_PH:
|
||
|
case Mips::PICK_QB:
|
||
|
case Mips::PRECRQU_S_QB_PH:
|
||
|
case Mips::PRECRQ_PH_W:
|
||
|
case Mips::PRECRQ_QB_PH:
|
||
|
case Mips::PRECRQ_RS_PH_W:
|
||
|
case Mips::PRECR_QB_PH: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DALIGN_MM64R6: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: bp
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 8;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DLSA:
|
||
|
case Mips::LSA: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: sa
|
||
|
op = getUImmWithOffsetEncoding<2, 1>(MI, 3, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADDU16_MMR6:
|
||
|
case Mips::SUBU16_MMR6: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 7;
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 4;
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 1;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MOVE16_MM:
|
||
|
case Mips::MOVE16_MMR6: {
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= op & UINT64_C(31);
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 5;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DI:
|
||
|
case Mips::DI_MM:
|
||
|
case Mips::DI_MMR6:
|
||
|
case Mips::EI:
|
||
|
case Mips::EI_MM:
|
||
|
case Mips::EI_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::EXTP:
|
||
|
case Mips::EXTPDP:
|
||
|
case Mips::EXTPDPV:
|
||
|
case Mips::EXTPV:
|
||
|
case Mips::EXTRV_RS_W:
|
||
|
case Mips::EXTRV_R_W:
|
||
|
case Mips::EXTRV_S_H:
|
||
|
case Mips::EXTRV_W:
|
||
|
case Mips::EXTR_RS_W:
|
||
|
case Mips::EXTR_R_W:
|
||
|
case Mips::EXTR_S_H:
|
||
|
case Mips::EXTR_W: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: ac
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 11;
|
||
|
// op: shift_rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LLD_R6:
|
||
|
case Mips::LL_R6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: addr
|
||
|
op = getMemEncoding(MI, 1, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(2031616)) << 5;
|
||
|
Value |= (op & UINT64_C(511)) << 7;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LB:
|
||
|
case Mips::LB64:
|
||
|
case Mips::LBu:
|
||
|
case Mips::LBu64:
|
||
|
case Mips::LD:
|
||
|
case Mips::LDC1:
|
||
|
case Mips::LDC164:
|
||
|
case Mips::LDC2:
|
||
|
case Mips::LDC3:
|
||
|
case Mips::LDL:
|
||
|
case Mips::LDR:
|
||
|
case Mips::LEA_ADDiu:
|
||
|
case Mips::LEA_ADDiu64:
|
||
|
case Mips::LH:
|
||
|
case Mips::LH64:
|
||
|
case Mips::LHu:
|
||
|
case Mips::LHu64:
|
||
|
case Mips::LL:
|
||
|
case Mips::LLD:
|
||
|
case Mips::LW:
|
||
|
case Mips::LW64:
|
||
|
case Mips::LWC1:
|
||
|
case Mips::LWC2:
|
||
|
case Mips::LWC3:
|
||
|
case Mips::LWL:
|
||
|
case Mips::LWL64:
|
||
|
case Mips::LWR:
|
||
|
case Mips::LWR64:
|
||
|
case Mips::LWu:
|
||
|
case Mips::SB:
|
||
|
case Mips::SB64:
|
||
|
case Mips::SD:
|
||
|
case Mips::SDC1:
|
||
|
case Mips::SDC164:
|
||
|
case Mips::SDC2:
|
||
|
case Mips::SDC3:
|
||
|
case Mips::SDL:
|
||
|
case Mips::SDR:
|
||
|
case Mips::SH:
|
||
|
case Mips::SH64:
|
||
|
case Mips::SW:
|
||
|
case Mips::SW64:
|
||
|
case Mips::SWC1:
|
||
|
case Mips::SWC2:
|
||
|
case Mips::SWC3:
|
||
|
case Mips::SWL:
|
||
|
case Mips::SWL64:
|
||
|
case Mips::SWR:
|
||
|
case Mips::SWR64: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: addr
|
||
|
op = getMemEncoding(MI, 1, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(2031616)) << 5;
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LDC2_R6:
|
||
|
case Mips::LWC2_R6:
|
||
|
case Mips::SDC2_R6:
|
||
|
case Mips::SWC2_R6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: addr
|
||
|
op = getMemEncoding(MI, 1, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(2031616)) >> 5;
|
||
|
Value |= op & UINT64_C(2047);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CFC1:
|
||
|
case Mips::DMFC1:
|
||
|
case Mips::MFC1:
|
||
|
case Mips::MFHC1_D32:
|
||
|
case Mips::MFHC1_D64: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DMFC2_OCTEON:
|
||
|
case Mips::DMTC2_OCTEON:
|
||
|
case Mips::LUi:
|
||
|
case Mips::LUi64:
|
||
|
case Mips::LUi_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: imm16
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BEQZALC:
|
||
|
case Mips::BGTZALC:
|
||
|
case Mips::BGTZC:
|
||
|
case Mips::BLEZALC:
|
||
|
case Mips::BLEZC:
|
||
|
case Mips::BNEZALC: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: offset
|
||
|
op = getBranchTargetOpValue(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::JIALC:
|
||
|
case Mips::JIALC_MMR6:
|
||
|
case Mips::JIC:
|
||
|
case Mips::JIC_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: offset
|
||
|
op = getJumpOffset16OpValue(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::RDHWR:
|
||
|
case Mips::RDHWR64: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DMFC0:
|
||
|
case Mips::DMFC2:
|
||
|
case Mips::MFC0:
|
||
|
case Mips::MFC2: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: sel
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= op & UINT64_C(7);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SLTi:
|
||
|
case Mips::SLTi64:
|
||
|
case Mips::SLTiu:
|
||
|
case Mips::SLTiu64: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: imm16
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CINS:
|
||
|
case Mips::CINS32:
|
||
|
case Mips::EXTS:
|
||
|
case Mips::EXTS32: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: pos
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: lenm1
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DINS:
|
||
|
case Mips::DINSM:
|
||
|
case Mips::DINSU:
|
||
|
case Mips::INS: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: pos
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: size
|
||
|
op = getSizeInsEncoding(MI, 3, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DEXT:
|
||
|
case Mips::DEXTM:
|
||
|
case Mips::DEXTU:
|
||
|
case Mips::EXT: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: pos
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: size
|
||
|
op = getUImmWithOffsetEncoding<5, 1>(MI, 3, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::APPEND:
|
||
|
case Mips::BALIGN:
|
||
|
case Mips::PREPEND: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: sa
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::INSV: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LBE_MM:
|
||
|
case Mips::LBuE_MM:
|
||
|
case Mips::LHE_MM:
|
||
|
case Mips::LHuE_MM:
|
||
|
case Mips::LWE_MM:
|
||
|
case Mips::SBE_MM:
|
||
|
case Mips::SHE_MM:
|
||
|
case Mips::SWE_MM:
|
||
|
case Mips::SWE_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: addr
|
||
|
op = getMemEncoding(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(2031616);
|
||
|
Value |= op & UINT64_C(511);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LB_MM:
|
||
|
case Mips::LBu_MM:
|
||
|
case Mips::LDC1_MM:
|
||
|
case Mips::LEA_ADDiu_MM:
|
||
|
case Mips::LH_MM:
|
||
|
case Mips::LHu_MM:
|
||
|
case Mips::LWC1_MM:
|
||
|
case Mips::LW_MM:
|
||
|
case Mips::LW_MMR6:
|
||
|
case Mips::SB_MM:
|
||
|
case Mips::SB_MMR6:
|
||
|
case Mips::SDC1_MM:
|
||
|
case Mips::SH_MM:
|
||
|
case Mips::SH_MMR6:
|
||
|
case Mips::SWC1_MM:
|
||
|
case Mips::SW_MM:
|
||
|
case Mips::SW_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: addr
|
||
|
op = getMemEncoding(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(2097151);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LL_MM:
|
||
|
case Mips::LWL_MM:
|
||
|
case Mips::LWR_MM:
|
||
|
case Mips::LWU_MM:
|
||
|
case Mips::SWL_MM:
|
||
|
case Mips::SWR_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: addr
|
||
|
op = getMemEncodingMMImm12(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(2031616);
|
||
|
Value |= op & UINT64_C(4095);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LLE_MM:
|
||
|
case Mips::LLE_MMR6:
|
||
|
case Mips::LWE_MMR6:
|
||
|
case Mips::LWLE_MM:
|
||
|
case Mips::LWRE_MM:
|
||
|
case Mips::SWLE_MM:
|
||
|
case Mips::SWRE_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: addr
|
||
|
op = getMemEncodingMMImm12(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(2031616);
|
||
|
Value |= op & UINT64_C(511);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SBE_MMR6:
|
||
|
case Mips::SCE_MMR6:
|
||
|
case Mips::SHE_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: addr
|
||
|
op = getMemEncodingMMImm9(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(2031616);
|
||
|
Value |= op & UINT64_C(511);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CFC1_MM:
|
||
|
case Mips::MFC1_MM:
|
||
|
case Mips::MFHC1_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::REPL_QB_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: imm
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(255)) << 13;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ALUIPC_MMR6:
|
||
|
case Mips::AUIPC_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: imm
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::EXTPDP_MM:
|
||
|
case Mips::EXTP_MM:
|
||
|
case Mips::EXTR_RS_W_MM:
|
||
|
case Mips::EXTR_R_W_MM:
|
||
|
case Mips::EXTR_S_H_MM:
|
||
|
case Mips::EXTR_W_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: imm
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: ac
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 14;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADDIUPC_MMR6:
|
||
|
case Mips::LWPC_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: imm
|
||
|
op = getSimm19Lsl2Encoding(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(524287);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LUI_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: imm16
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::RDDSP_MM:
|
||
|
case Mips::WRDSP_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: mask
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(127)) << 14;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BEQZALC_MMR6:
|
||
|
case Mips::BGTZALC_MMR6:
|
||
|
case Mips::BLEZALC_MMR6:
|
||
|
case Mips::BNEZALC_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: offset
|
||
|
op = getBranchTargetOpValueMM(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::RDHWR_MM:
|
||
|
case Mips::RDPGPR_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ABSQ_S_PH_MM:
|
||
|
case Mips::ABSQ_S_QB_MMR2:
|
||
|
case Mips::ABSQ_S_W_MM:
|
||
|
case Mips::PRECEQU_PH_QBLA_MM:
|
||
|
case Mips::PRECEQU_PH_QBL_MM:
|
||
|
case Mips::PRECEQU_PH_QBRA_MM:
|
||
|
case Mips::PRECEQU_PH_QBR_MM:
|
||
|
case Mips::PRECEQ_W_PHL_MM:
|
||
|
case Mips::PRECEQ_W_PHR_MM:
|
||
|
case Mips::PRECEU_PH_QBLA_MM:
|
||
|
case Mips::PRECEU_PH_QBL_MM:
|
||
|
case Mips::PRECEU_PH_QBRA_MM:
|
||
|
case Mips::PRECEU_PH_QBR_MM:
|
||
|
case Mips::RADDU_W_QB_MM:
|
||
|
case Mips::REPLV_PH_MM:
|
||
|
case Mips::REPLV_QB_MM:
|
||
|
case Mips::WRPGPR_MMR6:
|
||
|
case Mips::WSBH_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DAUI_MM64R6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: imm
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADDIU_MMR6:
|
||
|
case Mips::ANDI_MMR6:
|
||
|
case Mips::ORI_MMR6:
|
||
|
case Mips::SLTi_MM:
|
||
|
case Mips::SLTiu_MM:
|
||
|
case Mips::XORI_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: imm16
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::INS_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: pos
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: size
|
||
|
op = getSizeInsEncoding(MI, 3, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::EXT_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: pos
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: size
|
||
|
op = getUImmWithOffsetEncoding<5, 1>(MI, 3, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SHLL_PH_MM:
|
||
|
case Mips::SHLL_S_PH_MM:
|
||
|
case Mips::SHRA_PH_MM:
|
||
|
case Mips::SHRA_R_PH_MM:
|
||
|
case Mips::SHRL_PH_MMR2: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: sa
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(15)) << 12;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::PRECR_SRA_PH_W_MMR2:
|
||
|
case Mips::PRECR_SRA_R_PH_W_MMR2:
|
||
|
case Mips::PREPEND_MMR2:
|
||
|
case Mips::SHLL_S_W_MM:
|
||
|
case Mips::SHRA_R_W_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: sa
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SHLL_QB_MM:
|
||
|
case Mips::SHRA_QB_MMR2:
|
||
|
case Mips::SHRA_R_QB_MMR2:
|
||
|
case Mips::SHRL_QB_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: sa
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 13;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::RDHWR_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: sel
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DEXTM_MM64R6:
|
||
|
case Mips::DEXTU_MM64R6:
|
||
|
case Mips::DEXT_MM64R6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: size
|
||
|
op = getUImmWithOffsetEncoding<5, 1>(MI, 3, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: pos
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::INSV_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::EXTPDPV_MM:
|
||
|
case Mips::EXTPV_MM:
|
||
|
case Mips::EXTRV_RS_W_MM:
|
||
|
case Mips::EXTRV_R_W_MM:
|
||
|
case Mips::EXTRV_S_H_MM:
|
||
|
case Mips::EXTRV_W_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: ac
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 14;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BGEZALC:
|
||
|
case Mips::BGEZC:
|
||
|
case Mips::BLTZALC:
|
||
|
case Mips::BLTZC: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: offset
|
||
|
op = getBranchTargetOpValue(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BGEZALC_MMR6:
|
||
|
case Mips::BLTZALC_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: offset
|
||
|
op = getBranchTargetOpValueMM(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LWSP_MM:
|
||
|
case Mips::SWSP_MM:
|
||
|
case Mips::SWSP_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 5;
|
||
|
// op: offset
|
||
|
op = getMemEncodingMMSPImm5Lsl2(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(31);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::NOT16_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 3;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= op & UINT64_C(7);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LBU16_MM:
|
||
|
case Mips::SB16_MM:
|
||
|
case Mips::SB16_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 7;
|
||
|
// op: addr
|
||
|
op = getMemEncodingMMImm4(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(127);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LHU16_MM:
|
||
|
case Mips::SH16_MM:
|
||
|
case Mips::SH16_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 7;
|
||
|
// op: addr
|
||
|
op = getMemEncodingMMImm4Lsl1(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(127);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LW16_MM:
|
||
|
case Mips::SW16_MM:
|
||
|
case Mips::SW16_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 7;
|
||
|
// op: addr
|
||
|
op = getMemEncodingMMImm4Lsl2(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(127);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LWGP_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 7;
|
||
|
// op: offset
|
||
|
op = getMemEncodingMMGPImm7Lsl2(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(127);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::NOT16_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 7;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 4;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SCD_R6:
|
||
|
case Mips::SC_R6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: addr
|
||
|
op = getMemEncoding(MI, 2, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(2031616)) << 5;
|
||
|
Value |= (op & UINT64_C(511)) << 7;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SC:
|
||
|
case Mips::SCD: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: addr
|
||
|
op = getMemEncoding(MI, 2, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(2031616)) << 5;
|
||
|
Value |= op & UINT64_C(65535);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CTC1:
|
||
|
case Mips::DMTC1:
|
||
|
case Mips::MTC1: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DMTC0:
|
||
|
case Mips::DMTC2:
|
||
|
case Mips::MTC0:
|
||
|
case Mips::MTC2: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: sel
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= op & UINT64_C(7);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SC_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: addr
|
||
|
op = getMemEncodingMMImm12(MI, 2, Fixups, STI);
|
||
|
Value |= op & UINT64_C(2031616);
|
||
|
Value |= op & UINT64_C(4095);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SCE_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: addr
|
||
|
op = getMemEncodingMMImm12(MI, 2, Fixups, STI);
|
||
|
Value |= op & UINT64_C(2031616);
|
||
|
Value |= op & UINT64_C(511);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CTC1_MM:
|
||
|
case Mips::MTC1_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MTHC1_D32:
|
||
|
case Mips::MTHC1_D64: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SPLAT_B:
|
||
|
case Mips::SPLAT_D:
|
||
|
case Mips::SPLAT_H:
|
||
|
case Mips::SPLAT_W: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MTHC1_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: fs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::DPAQX_SA_W_PH_MMR2:
|
||
|
case Mips::DPAQX_S_W_PH_MMR2:
|
||
|
case Mips::DPAQ_SA_L_W_MM:
|
||
|
case Mips::DPAQ_S_W_PH_MM:
|
||
|
case Mips::DPAU_H_QBL_MM:
|
||
|
case Mips::DPAU_H_QBR_MM:
|
||
|
case Mips::DPAX_W_PH_MMR2:
|
||
|
case Mips::DPA_W_PH_MMR2:
|
||
|
case Mips::DPSQX_SA_W_PH_MMR2:
|
||
|
case Mips::DPSQX_S_W_PH_MMR2:
|
||
|
case Mips::DPSQ_SA_L_W_MM:
|
||
|
case Mips::DPSQ_S_W_PH_MM:
|
||
|
case Mips::DPSU_H_QBL_MM:
|
||
|
case Mips::DPSU_H_QBR_MM:
|
||
|
case Mips::DPSX_W_PH_MMR2:
|
||
|
case Mips::DPS_W_PH_MMR2:
|
||
|
case Mips::MADDU_DSP_MM:
|
||
|
case Mips::MADD_DSP_MM:
|
||
|
case Mips::MAQ_SA_W_PHL_MM:
|
||
|
case Mips::MAQ_SA_W_PHR_MM:
|
||
|
case Mips::MAQ_S_W_PHL_MM:
|
||
|
case Mips::MAQ_S_W_PHR_MM:
|
||
|
case Mips::MSUBU_DSP_MM:
|
||
|
case Mips::MSUB_DSP_MM:
|
||
|
case Mips::MULTU_DSP_MM:
|
||
|
case Mips::MULT_DSP_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: ac
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 14;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADD_MM:
|
||
|
case Mips::ADDu_MM:
|
||
|
case Mips::AND_MM:
|
||
|
case Mips::MOVN_I_MM:
|
||
|
case Mips::MOVZ_I_MM:
|
||
|
case Mips::MUL_MM:
|
||
|
case Mips::NOR_MM:
|
||
|
case Mips::OR_MM:
|
||
|
case Mips::SLT_MM:
|
||
|
case Mips::SLTu_MM:
|
||
|
case Mips::SUB_MM:
|
||
|
case Mips::SUBu_MM:
|
||
|
case Mips::XOR_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: rd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::AND16_MM:
|
||
|
case Mips::OR16_MM:
|
||
|
case Mips::XOR16_MM: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 3;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= op & UINT64_C(7);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::AND16_MMR6:
|
||
|
case Mips::OR16_MMR6:
|
||
|
case Mips::XOR16_MMR6: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 7;
|
||
|
// op: rs
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 4;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SLD_B:
|
||
|
case Mips::SLD_D:
|
||
|
case Mips::SLD_H:
|
||
|
case Mips::SLD_W: {
|
||
|
// op: rt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LWM32_MM:
|
||
|
case Mips::SWM32_MM: {
|
||
|
// op: rt
|
||
|
op = getRegisterListOpValue(MI, 0, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: addr
|
||
|
op = getMemEncodingMMImm12(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(2031616);
|
||
|
Value |= op & UINT64_C(4095);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LWM16_MM:
|
||
|
case Mips::SWM16_MM: {
|
||
|
// op: rt
|
||
|
op = getRegisterListOpValue16(MI, 0, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 4;
|
||
|
// op: addr
|
||
|
op = getMemEncodingMMImm4sp(MI, 1, Fixups, STI);
|
||
|
Value |= op & UINT64_C(15);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LWM16_MMR6:
|
||
|
case Mips::SWM16_MMR6: {
|
||
|
// op: rt
|
||
|
op = getRegisterListOpValue16(MI, 0, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 8;
|
||
|
// op: addr
|
||
|
op = getMemEncodingMMImm4sp(MI, 1, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(15)) << 4;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LWP_MM:
|
||
|
case Mips::SWP_MM: {
|
||
|
// op: rt
|
||
|
op = getRegisterPairOpValue(MI, 0, Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 21;
|
||
|
// op: addr
|
||
|
op = getMemEncodingMMImm12(MI, 2, Fixups, STI);
|
||
|
Value |= op & UINT64_C(2031616);
|
||
|
Value |= op & UINT64_C(4095);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::JrcRx16:
|
||
|
case Mips::JumpLinkReg16:
|
||
|
case Mips::SebRx16:
|
||
|
case Mips::SehRx16: {
|
||
|
// op: rx
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 8;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::AddiuRxRxImm16:
|
||
|
case Mips::BeqzRxImm16:
|
||
|
case Mips::BnezRxImm16:
|
||
|
case Mips::CmpiRxImm16:
|
||
|
case Mips::LiRxImm16:
|
||
|
case Mips::LwRxPcTcp16:
|
||
|
case Mips::SltiRxImm16:
|
||
|
case Mips::SltiuRxImm16: {
|
||
|
// op: rx
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 8;
|
||
|
// op: imm8
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= op & UINT64_C(255);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::Mfhi16:
|
||
|
case Mips::Mflo16: {
|
||
|
// op: rx
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 8;
|
||
|
// op: ry
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 5;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::CmpRxRy16:
|
||
|
case Mips::DivRxRy16:
|
||
|
case Mips::DivuRxRy16:
|
||
|
case Mips::NegRxRy16:
|
||
|
case Mips::NotRxRy16:
|
||
|
case Mips::SltRxRy16:
|
||
|
case Mips::SltuRxRy16: {
|
||
|
// op: rx
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 8;
|
||
|
// op: ry
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 5;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::AndRxRxRy16:
|
||
|
case Mips::OrRxRxRy16:
|
||
|
case Mips::SllvRxRy16:
|
||
|
case Mips::SravRxRy16:
|
||
|
case Mips::SrlvRxRy16:
|
||
|
case Mips::XorRxRxRy16: {
|
||
|
// op: rx
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 8;
|
||
|
// op: ry
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 5;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::AdduRxRyRz16:
|
||
|
case Mips::SubuRxRyRz16: {
|
||
|
// op: rx
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 8;
|
||
|
// op: ry
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 5;
|
||
|
// op: rz
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 2;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::MoveR3216: {
|
||
|
// op: ry
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(15)) << 4;
|
||
|
// op: r32
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= op & UINT64_C(15);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::LDI_B:
|
||
|
case Mips::LDI_D:
|
||
|
case Mips::LDI_H:
|
||
|
case Mips::LDI_W: {
|
||
|
// op: s10
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(1023)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SllX16:
|
||
|
case Mips::SraX16:
|
||
|
case Mips::SrlX16: {
|
||
|
// op: sa6
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 22;
|
||
|
Value |= (op & UINT64_C(32)) << 16;
|
||
|
// op: rx
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 8;
|
||
|
// op: ry
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 5;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SHILO_MM: {
|
||
|
// op: shift
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(63)) << 16;
|
||
|
// op: ac
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(3)) << 14;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SYNC_MM:
|
||
|
case Mips::SYNC_MMR6: {
|
||
|
// op: stype
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::SYNC: {
|
||
|
// op: stype
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::J:
|
||
|
case Mips::JAL:
|
||
|
case Mips::JALX:
|
||
|
case Mips::JALX_MM: {
|
||
|
// op: target
|
||
|
op = getJumpTargetOpValue(MI, 0, Fixups, STI);
|
||
|
Value |= op & UINT64_C(67108863);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::JALS_MM:
|
||
|
case Mips::JAL_MM:
|
||
|
case Mips::J_MM: {
|
||
|
// op: target
|
||
|
op = getJumpTargetOpValueMM(MI, 0, Fixups, STI);
|
||
|
Value |= op & UINT64_C(67108863);
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ANDI_B:
|
||
|
case Mips::NORI_B:
|
||
|
case Mips::ORI_B:
|
||
|
case Mips::SHF_B:
|
||
|
case Mips::SHF_H:
|
||
|
case Mips::SHF_W:
|
||
|
case Mips::XORI_B: {
|
||
|
// op: u8
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(255)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BMNZI_B:
|
||
|
case Mips::BMZI_B:
|
||
|
case Mips::BSELI_B: {
|
||
|
// op: u8
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(255)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::FCLASS_D:
|
||
|
case Mips::FCLASS_W:
|
||
|
case Mips::FEXUPL_D:
|
||
|
case Mips::FEXUPL_W:
|
||
|
case Mips::FEXUPR_D:
|
||
|
case Mips::FEXUPR_W:
|
||
|
case Mips::FFINT_S_D:
|
||
|
case Mips::FFINT_S_W:
|
||
|
case Mips::FFINT_U_D:
|
||
|
case Mips::FFINT_U_W:
|
||
|
case Mips::FFQL_D:
|
||
|
case Mips::FFQL_W:
|
||
|
case Mips::FFQR_D:
|
||
|
case Mips::FFQR_W:
|
||
|
case Mips::FLOG2_D:
|
||
|
case Mips::FLOG2_W:
|
||
|
case Mips::FRCP_D:
|
||
|
case Mips::FRCP_W:
|
||
|
case Mips::FRINT_D:
|
||
|
case Mips::FRINT_W:
|
||
|
case Mips::FRSQRT_D:
|
||
|
case Mips::FRSQRT_W:
|
||
|
case Mips::FSQRT_D:
|
||
|
case Mips::FSQRT_W:
|
||
|
case Mips::FTINT_S_D:
|
||
|
case Mips::FTINT_S_W:
|
||
|
case Mips::FTINT_U_D:
|
||
|
case Mips::FTINT_U_W:
|
||
|
case Mips::FTRUNC_S_D:
|
||
|
case Mips::FTRUNC_S_W:
|
||
|
case Mips::FTRUNC_U_D:
|
||
|
case Mips::FTRUNC_U_W:
|
||
|
case Mips::MOVE_V:
|
||
|
case Mips::NLOC_B:
|
||
|
case Mips::NLOC_D:
|
||
|
case Mips::NLOC_H:
|
||
|
case Mips::NLOC_W:
|
||
|
case Mips::NLZC_B:
|
||
|
case Mips::NLZC_D:
|
||
|
case Mips::NLZC_H:
|
||
|
case Mips::NLZC_W:
|
||
|
case Mips::PCNT_B:
|
||
|
case Mips::PCNT_D:
|
||
|
case Mips::PCNT_H:
|
||
|
case Mips::PCNT_W: {
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BCLRI_H:
|
||
|
case Mips::BNEGI_H:
|
||
|
case Mips::BSETI_H:
|
||
|
case Mips::SAT_S_H:
|
||
|
case Mips::SAT_U_H:
|
||
|
case Mips::SLLI_H:
|
||
|
case Mips::SRAI_H:
|
||
|
case Mips::SRARI_H:
|
||
|
case Mips::SRLI_H:
|
||
|
case Mips::SRLRI_H: {
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: m
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(15)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BCLRI_W:
|
||
|
case Mips::BNEGI_W:
|
||
|
case Mips::BSETI_W:
|
||
|
case Mips::SAT_S_W:
|
||
|
case Mips::SAT_U_W:
|
||
|
case Mips::SLLI_W:
|
||
|
case Mips::SRAI_W:
|
||
|
case Mips::SRARI_W:
|
||
|
case Mips::SRLI_W:
|
||
|
case Mips::SRLRI_W: {
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: m
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BCLRI_D:
|
||
|
case Mips::BNEGI_D:
|
||
|
case Mips::BSETI_D:
|
||
|
case Mips::SAT_S_D:
|
||
|
case Mips::SAT_U_D:
|
||
|
case Mips::SLLI_D:
|
||
|
case Mips::SRAI_D:
|
||
|
case Mips::SRARI_D:
|
||
|
case Mips::SRLI_D:
|
||
|
case Mips::SRLRI_D: {
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: m
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(63)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BCLRI_B:
|
||
|
case Mips::BNEGI_B:
|
||
|
case Mips::BSETI_B:
|
||
|
case Mips::SAT_S_B:
|
||
|
case Mips::SAT_U_B:
|
||
|
case Mips::SLLI_B:
|
||
|
case Mips::SRAI_B:
|
||
|
case Mips::SRARI_B:
|
||
|
case Mips::SRLI_B:
|
||
|
case Mips::SRLRI_B: {
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: m
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BINSLI_H:
|
||
|
case Mips::BINSRI_H: {
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: m
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(15)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BINSLI_W:
|
||
|
case Mips::BINSRI_W: {
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: m
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BINSLI_D:
|
||
|
case Mips::BINSRI_D: {
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: m
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(63)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BINSLI_B:
|
||
|
case Mips::BINSRI_B: {
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
// op: m
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(7)) << 16;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::ADDS_A_B:
|
||
|
case Mips::ADDS_A_D:
|
||
|
case Mips::ADDS_A_H:
|
||
|
case Mips::ADDS_A_W:
|
||
|
case Mips::ADDS_S_B:
|
||
|
case Mips::ADDS_S_D:
|
||
|
case Mips::ADDS_S_H:
|
||
|
case Mips::ADDS_S_W:
|
||
|
case Mips::ADDS_U_B:
|
||
|
case Mips::ADDS_U_D:
|
||
|
case Mips::ADDS_U_H:
|
||
|
case Mips::ADDS_U_W:
|
||
|
case Mips::ADDV_B:
|
||
|
case Mips::ADDV_D:
|
||
|
case Mips::ADDV_H:
|
||
|
case Mips::ADDV_W:
|
||
|
case Mips::ADD_A_B:
|
||
|
case Mips::ADD_A_D:
|
||
|
case Mips::ADD_A_H:
|
||
|
case Mips::ADD_A_W:
|
||
|
case Mips::AND_V:
|
||
|
case Mips::ASUB_S_B:
|
||
|
case Mips::ASUB_S_D:
|
||
|
case Mips::ASUB_S_H:
|
||
|
case Mips::ASUB_S_W:
|
||
|
case Mips::ASUB_U_B:
|
||
|
case Mips::ASUB_U_D:
|
||
|
case Mips::ASUB_U_H:
|
||
|
case Mips::ASUB_U_W:
|
||
|
case Mips::AVER_S_B:
|
||
|
case Mips::AVER_S_D:
|
||
|
case Mips::AVER_S_H:
|
||
|
case Mips::AVER_S_W:
|
||
|
case Mips::AVER_U_B:
|
||
|
case Mips::AVER_U_D:
|
||
|
case Mips::AVER_U_H:
|
||
|
case Mips::AVER_U_W:
|
||
|
case Mips::AVE_S_B:
|
||
|
case Mips::AVE_S_D:
|
||
|
case Mips::AVE_S_H:
|
||
|
case Mips::AVE_S_W:
|
||
|
case Mips::AVE_U_B:
|
||
|
case Mips::AVE_U_D:
|
||
|
case Mips::AVE_U_H:
|
||
|
case Mips::AVE_U_W:
|
||
|
case Mips::BCLR_B:
|
||
|
case Mips::BCLR_D:
|
||
|
case Mips::BCLR_H:
|
||
|
case Mips::BCLR_W:
|
||
|
case Mips::BNEG_B:
|
||
|
case Mips::BNEG_D:
|
||
|
case Mips::BNEG_H:
|
||
|
case Mips::BNEG_W:
|
||
|
case Mips::BSET_B:
|
||
|
case Mips::BSET_D:
|
||
|
case Mips::BSET_H:
|
||
|
case Mips::BSET_W:
|
||
|
case Mips::CEQ_B:
|
||
|
case Mips::CEQ_D:
|
||
|
case Mips::CEQ_H:
|
||
|
case Mips::CEQ_W:
|
||
|
case Mips::CLE_S_B:
|
||
|
case Mips::CLE_S_D:
|
||
|
case Mips::CLE_S_H:
|
||
|
case Mips::CLE_S_W:
|
||
|
case Mips::CLE_U_B:
|
||
|
case Mips::CLE_U_D:
|
||
|
case Mips::CLE_U_H:
|
||
|
case Mips::CLE_U_W:
|
||
|
case Mips::CLT_S_B:
|
||
|
case Mips::CLT_S_D:
|
||
|
case Mips::CLT_S_H:
|
||
|
case Mips::CLT_S_W:
|
||
|
case Mips::CLT_U_B:
|
||
|
case Mips::CLT_U_D:
|
||
|
case Mips::CLT_U_H:
|
||
|
case Mips::CLT_U_W:
|
||
|
case Mips::DIV_S_B:
|
||
|
case Mips::DIV_S_D:
|
||
|
case Mips::DIV_S_H:
|
||
|
case Mips::DIV_S_W:
|
||
|
case Mips::DIV_U_B:
|
||
|
case Mips::DIV_U_D:
|
||
|
case Mips::DIV_U_H:
|
||
|
case Mips::DIV_U_W:
|
||
|
case Mips::DOTP_S_D:
|
||
|
case Mips::DOTP_S_H:
|
||
|
case Mips::DOTP_S_W:
|
||
|
case Mips::DOTP_U_D:
|
||
|
case Mips::DOTP_U_H:
|
||
|
case Mips::DOTP_U_W:
|
||
|
case Mips::FADD_D:
|
||
|
case Mips::FADD_W:
|
||
|
case Mips::FCAF_D:
|
||
|
case Mips::FCAF_W:
|
||
|
case Mips::FCEQ_D:
|
||
|
case Mips::FCEQ_W:
|
||
|
case Mips::FCLE_D:
|
||
|
case Mips::FCLE_W:
|
||
|
case Mips::FCLT_D:
|
||
|
case Mips::FCLT_W:
|
||
|
case Mips::FCNE_D:
|
||
|
case Mips::FCNE_W:
|
||
|
case Mips::FCOR_D:
|
||
|
case Mips::FCOR_W:
|
||
|
case Mips::FCUEQ_D:
|
||
|
case Mips::FCUEQ_W:
|
||
|
case Mips::FCULE_D:
|
||
|
case Mips::FCULE_W:
|
||
|
case Mips::FCULT_D:
|
||
|
case Mips::FCULT_W:
|
||
|
case Mips::FCUNE_D:
|
||
|
case Mips::FCUNE_W:
|
||
|
case Mips::FCUN_D:
|
||
|
case Mips::FCUN_W:
|
||
|
case Mips::FDIV_D:
|
||
|
case Mips::FDIV_W:
|
||
|
case Mips::FEXDO_H:
|
||
|
case Mips::FEXDO_W:
|
||
|
case Mips::FEXP2_D:
|
||
|
case Mips::FEXP2_W:
|
||
|
case Mips::FMAX_A_D:
|
||
|
case Mips::FMAX_A_W:
|
||
|
case Mips::FMAX_D:
|
||
|
case Mips::FMAX_W:
|
||
|
case Mips::FMIN_A_D:
|
||
|
case Mips::FMIN_A_W:
|
||
|
case Mips::FMIN_D:
|
||
|
case Mips::FMIN_W:
|
||
|
case Mips::FMUL_D:
|
||
|
case Mips::FMUL_W:
|
||
|
case Mips::FSAF_D:
|
||
|
case Mips::FSAF_W:
|
||
|
case Mips::FSEQ_D:
|
||
|
case Mips::FSEQ_W:
|
||
|
case Mips::FSLE_D:
|
||
|
case Mips::FSLE_W:
|
||
|
case Mips::FSLT_D:
|
||
|
case Mips::FSLT_W:
|
||
|
case Mips::FSNE_D:
|
||
|
case Mips::FSNE_W:
|
||
|
case Mips::FSOR_D:
|
||
|
case Mips::FSOR_W:
|
||
|
case Mips::FSUB_D:
|
||
|
case Mips::FSUB_W:
|
||
|
case Mips::FSUEQ_D:
|
||
|
case Mips::FSUEQ_W:
|
||
|
case Mips::FSULE_D:
|
||
|
case Mips::FSULE_W:
|
||
|
case Mips::FSULT_D:
|
||
|
case Mips::FSULT_W:
|
||
|
case Mips::FSUNE_D:
|
||
|
case Mips::FSUNE_W:
|
||
|
case Mips::FSUN_D:
|
||
|
case Mips::FSUN_W:
|
||
|
case Mips::FTQ_H:
|
||
|
case Mips::FTQ_W:
|
||
|
case Mips::HADD_S_D:
|
||
|
case Mips::HADD_S_H:
|
||
|
case Mips::HADD_S_W:
|
||
|
case Mips::HADD_U_D:
|
||
|
case Mips::HADD_U_H:
|
||
|
case Mips::HADD_U_W:
|
||
|
case Mips::HSUB_S_D:
|
||
|
case Mips::HSUB_S_H:
|
||
|
case Mips::HSUB_S_W:
|
||
|
case Mips::HSUB_U_D:
|
||
|
case Mips::HSUB_U_H:
|
||
|
case Mips::HSUB_U_W:
|
||
|
case Mips::ILVEV_B:
|
||
|
case Mips::ILVEV_D:
|
||
|
case Mips::ILVEV_H:
|
||
|
case Mips::ILVEV_W:
|
||
|
case Mips::ILVL_B:
|
||
|
case Mips::ILVL_D:
|
||
|
case Mips::ILVL_H:
|
||
|
case Mips::ILVL_W:
|
||
|
case Mips::ILVOD_B:
|
||
|
case Mips::ILVOD_D:
|
||
|
case Mips::ILVOD_H:
|
||
|
case Mips::ILVOD_W:
|
||
|
case Mips::ILVR_B:
|
||
|
case Mips::ILVR_D:
|
||
|
case Mips::ILVR_H:
|
||
|
case Mips::ILVR_W:
|
||
|
case Mips::MAX_A_B:
|
||
|
case Mips::MAX_A_D:
|
||
|
case Mips::MAX_A_H:
|
||
|
case Mips::MAX_A_W:
|
||
|
case Mips::MAX_S_B:
|
||
|
case Mips::MAX_S_D:
|
||
|
case Mips::MAX_S_H:
|
||
|
case Mips::MAX_S_W:
|
||
|
case Mips::MAX_U_B:
|
||
|
case Mips::MAX_U_D:
|
||
|
case Mips::MAX_U_H:
|
||
|
case Mips::MAX_U_W:
|
||
|
case Mips::MIN_A_B:
|
||
|
case Mips::MIN_A_D:
|
||
|
case Mips::MIN_A_H:
|
||
|
case Mips::MIN_A_W:
|
||
|
case Mips::MIN_S_B:
|
||
|
case Mips::MIN_S_D:
|
||
|
case Mips::MIN_S_H:
|
||
|
case Mips::MIN_S_W:
|
||
|
case Mips::MIN_U_B:
|
||
|
case Mips::MIN_U_D:
|
||
|
case Mips::MIN_U_H:
|
||
|
case Mips::MIN_U_W:
|
||
|
case Mips::MOD_S_B:
|
||
|
case Mips::MOD_S_D:
|
||
|
case Mips::MOD_S_H:
|
||
|
case Mips::MOD_S_W:
|
||
|
case Mips::MOD_U_B:
|
||
|
case Mips::MOD_U_D:
|
||
|
case Mips::MOD_U_H:
|
||
|
case Mips::MOD_U_W:
|
||
|
case Mips::MULR_Q_H:
|
||
|
case Mips::MULR_Q_W:
|
||
|
case Mips::MULV_B:
|
||
|
case Mips::MULV_D:
|
||
|
case Mips::MULV_H:
|
||
|
case Mips::MULV_W:
|
||
|
case Mips::MUL_Q_H:
|
||
|
case Mips::MUL_Q_W:
|
||
|
case Mips::NOR_V:
|
||
|
case Mips::OR_V:
|
||
|
case Mips::PCKEV_B:
|
||
|
case Mips::PCKEV_D:
|
||
|
case Mips::PCKEV_H:
|
||
|
case Mips::PCKEV_W:
|
||
|
case Mips::PCKOD_B:
|
||
|
case Mips::PCKOD_D:
|
||
|
case Mips::PCKOD_H:
|
||
|
case Mips::PCKOD_W:
|
||
|
case Mips::SLL_B:
|
||
|
case Mips::SLL_D:
|
||
|
case Mips::SLL_H:
|
||
|
case Mips::SLL_W:
|
||
|
case Mips::SRAR_B:
|
||
|
case Mips::SRAR_D:
|
||
|
case Mips::SRAR_H:
|
||
|
case Mips::SRAR_W:
|
||
|
case Mips::SRA_B:
|
||
|
case Mips::SRA_D:
|
||
|
case Mips::SRA_H:
|
||
|
case Mips::SRA_W:
|
||
|
case Mips::SRLR_B:
|
||
|
case Mips::SRLR_D:
|
||
|
case Mips::SRLR_H:
|
||
|
case Mips::SRLR_W:
|
||
|
case Mips::SRL_B:
|
||
|
case Mips::SRL_D:
|
||
|
case Mips::SRL_H:
|
||
|
case Mips::SRL_W:
|
||
|
case Mips::SUBSUS_U_B:
|
||
|
case Mips::SUBSUS_U_D:
|
||
|
case Mips::SUBSUS_U_H:
|
||
|
case Mips::SUBSUS_U_W:
|
||
|
case Mips::SUBSUU_S_B:
|
||
|
case Mips::SUBSUU_S_D:
|
||
|
case Mips::SUBSUU_S_H:
|
||
|
case Mips::SUBSUU_S_W:
|
||
|
case Mips::SUBS_S_B:
|
||
|
case Mips::SUBS_S_D:
|
||
|
case Mips::SUBS_S_H:
|
||
|
case Mips::SUBS_S_W:
|
||
|
case Mips::SUBS_U_B:
|
||
|
case Mips::SUBS_U_D:
|
||
|
case Mips::SUBS_U_H:
|
||
|
case Mips::SUBS_U_W:
|
||
|
case Mips::SUBV_B:
|
||
|
case Mips::SUBV_D:
|
||
|
case Mips::SUBV_H:
|
||
|
case Mips::SUBV_W:
|
||
|
case Mips::XOR_V: {
|
||
|
// op: wt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(1), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
case Mips::BINSL_B:
|
||
|
case Mips::BINSL_D:
|
||
|
case Mips::BINSL_H:
|
||
|
case Mips::BINSL_W:
|
||
|
case Mips::BINSR_B:
|
||
|
case Mips::BINSR_D:
|
||
|
case Mips::BINSR_H:
|
||
|
case Mips::BINSR_W:
|
||
|
case Mips::BMNZ_V:
|
||
|
case Mips::BMZ_V:
|
||
|
case Mips::BSEL_V:
|
||
|
case Mips::DPADD_S_D:
|
||
|
case Mips::DPADD_S_H:
|
||
|
case Mips::DPADD_S_W:
|
||
|
case Mips::DPADD_U_D:
|
||
|
case Mips::DPADD_U_H:
|
||
|
case Mips::DPADD_U_W:
|
||
|
case Mips::DPSUB_S_D:
|
||
|
case Mips::DPSUB_S_H:
|
||
|
case Mips::DPSUB_S_W:
|
||
|
case Mips::DPSUB_U_D:
|
||
|
case Mips::DPSUB_U_H:
|
||
|
case Mips::DPSUB_U_W:
|
||
|
case Mips::FMADD_D:
|
||
|
case Mips::FMADD_W:
|
||
|
case Mips::FMSUB_D:
|
||
|
case Mips::FMSUB_W:
|
||
|
case Mips::MADDR_Q_H:
|
||
|
case Mips::MADDR_Q_W:
|
||
|
case Mips::MADDV_B:
|
||
|
case Mips::MADDV_D:
|
||
|
case Mips::MADDV_H:
|
||
|
case Mips::MADDV_W:
|
||
|
case Mips::MADD_Q_H:
|
||
|
case Mips::MADD_Q_W:
|
||
|
case Mips::MSUBR_Q_H:
|
||
|
case Mips::MSUBR_Q_W:
|
||
|
case Mips::MSUBV_B:
|
||
|
case Mips::MSUBV_D:
|
||
|
case Mips::MSUBV_H:
|
||
|
case Mips::MSUBV_W:
|
||
|
case Mips::MSUB_Q_H:
|
||
|
case Mips::MSUB_Q_W:
|
||
|
case Mips::VSHF_B:
|
||
|
case Mips::VSHF_D:
|
||
|
case Mips::VSHF_H:
|
||
|
case Mips::VSHF_W: {
|
||
|
// op: wt
|
||
|
op = getMachineOpValue(MI, MI.getOperand(3), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 16;
|
||
|
// op: ws
|
||
|
op = getMachineOpValue(MI, MI.getOperand(2), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 11;
|
||
|
// op: wd
|
||
|
op = getMachineOpValue(MI, MI.getOperand(0), Fixups, STI);
|
||
|
Value |= (op & UINT64_C(31)) << 6;
|
||
|
break;
|
||
|
}
|
||
|
default:
|
||
|
std::string msg;
|
||
|
raw_string_ostream Msg(msg);
|
||
|
Msg << "Not supported instr: " << MI;
|
||
|
report_fatal_error(Msg.str());
|
||
|
}
|
||
|
return Value;
|
||
|
}
|
||
|
|