1624 lines
		
	
	
		
			72 KiB
		
	
	
	
		
			TableGen
		
	
	
	
			
		
		
	
	
			1624 lines
		
	
	
		
			72 KiB
		
	
	
	
		
			TableGen
		
	
	
	
| //=- MipsScheduleGeneric.td - Generic Scheduling Definitions -*- tablegen -*-=//
 | |
| //
 | |
| // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
 | |
| // See https://llvm.org/LICENSE.txt for license information.
 | |
| // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| //
 | |
| // This file describes the interAptiv processor in a manner of speaking. It
 | |
| // describes a hypothetical version of the in-order MIPS32R2 interAptiv with all
 | |
| // branches of the MIPS ISAs, ASEs and ISA variants. The itinerary lists are
 | |
| // broken down into per ISA lists, so that this file can be used to rapidly
 | |
| // develop new schedule models.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| def MipsGenericModel : SchedMachineModel {
 | |
|   int IssueWidth = 1;
 | |
|   int MicroOpBufferSize = 0;
 | |
| 
 | |
|   // These figures assume an L1 hit.
 | |
|   int LoadLatency = 2;
 | |
|   int MispredictPenalty = 4;
 | |
| 
 | |
|   int HighLatency = 37;
 | |
|   list<Predicate> UnsupportedFeatures = [];
 | |
| 
 | |
|   let CompleteModel = 1;
 | |
|   let PostRAScheduler = 1;
 | |
| 
 | |
|   // FIXME: Remove when all errors have been fixed.
 | |
|   let FullInstRWOverlapCheck = 1;
 | |
| }
 | |
| 
 | |
| let SchedModel = MipsGenericModel in {
 | |
| 
 | |
| // ALU Pipeline
 | |
| // ============
 | |
| 
 | |
| def GenericALU : ProcResource<1> { let BufferSize = 1; }
 | |
| def GenericIssueALU : ProcResource<1> { let Super = GenericALU; }
 | |
| 
 | |
| def GenericWriteALU : SchedWriteRes<[GenericIssueALU]>;
 | |
| 
 | |
| // add, addi, addiu, addu, and, andi, clo, clz, ext, ins, lui, nor, or, ori,
 | |
| // rotr, rotrv, seb, seh, sll, sllv, slt, slti, sltiu, sltu, sra, srav, srl,
 | |
| // srlv, ssnop, sub, subu, wsbh, xor, xori
 | |
| def : InstRW<[GenericWriteALU], (instrs ADD, ADDi, ADDiu, ADDu, AND, ANDi,
 | |
|                                  CLO, CLZ, EXT, INS, LEA_ADDiu, LUi, NOP,
 | |
|                                  NOR, OR, ORi, ROTR, ROTRV, SEB, SEH, SLL,
 | |
|                                  SLLV, SLT, SLTi, SLTiu, SLTu, SRA, SRAV, SRL,
 | |
|                                  SRLV, SSNOP, SUB, SUBu, WSBH, XOR, XORi)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteALU], (instrs COPY)>;
 | |
| 
 | |
| // MIPSR6
 | |
| // ======
 | |
| 
 | |
| // addiupc, align, aluipc, aui, auipc, bitswap, clo, clz, lsa, seleqz, selnez
 | |
| def : InstRW<[GenericWriteALU], (instrs ADDIUPC, ALIGN, ALUIPC, AUI,
 | |
|                                  AUIPC, BITSWAP, CLO_R6, CLZ_R6, LSA_R6,
 | |
|                                  SELEQZ, SELNEZ)>;
 | |
| 
 | |
| // MIPS16e
 | |
| // =======
 | |
| 
 | |
| def : InstRW<[GenericWriteALU], (instrs AddiuRxImmX16, AddiuRxRxImm16,
 | |
|                                  AddiuRxRxImmX16, AddiuRxRyOffMemX16,
 | |
|                                  AddiuRxPcImmX16, AddiuSpImm16, AddiuSpImmX16,
 | |
|                                  AdduRxRyRz16, AndRxRxRy16, CmpRxRy16,
 | |
|                                  CmpiRxImm16, CmpiRxImmX16, LiRxImm16,
 | |
|                                  LiRxImmX16, LiRxImmAlignX16, Move32R16,
 | |
|                                  MoveR3216, Mfhi16, Mflo16, NegRxRy16,
 | |
|                                  NotRxRy16, OrRxRxRy16, SebRx16, SehRx16,
 | |
|                                  SllX16, SllvRxRy16, SltiRxImm16,
 | |
|                                  SltiRxImmX16, SltiCCRxImmX16,
 | |
|                                  SltiuRxImm16, SltiuRxImmX16, SltiuCCRxImmX16,
 | |
|                                  SltRxRy16, SltCCRxRy16, SltuRxRy16,
 | |
|                                  SltuRxRyRz16, SltuCCRxRy16, SravRxRy16,
 | |
|                                  SraX16, SrlvRxRy16, SrlX16, SubuRxRyRz16,
 | |
|                                  XorRxRxRy16)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteALU], (instrs Constant32, LwConstant32,
 | |
|                                  GotPrologue16, CONSTPOOL_ENTRY)>;
 | |
| 
 | |
| // microMIPS
 | |
| // =========
 | |
| 
 | |
| def : InstRW<[GenericWriteALU], (instrs ADDIUPC_MM, ADDIUR1SP_MM, ADDIUR2_MM,
 | |
|                                  ADDIUS5_MM, ADDIUSP_MM, ADDU16_MM, ADD_MM,
 | |
|                                  ADDi_MM, ADDiu_MM, ADDu_MM, AND16_MM,
 | |
|                                  ANDI16_MM, AND_MM, ANDi_MM, CLO_MM, CLZ_MM,
 | |
|                                  EXT_MM, INS_MM, LEA_ADDiu_MM, LI16_MM,
 | |
|                                  LUi_MM, MOVE16_MM, MOVEP_MM, NOR_MM,
 | |
|                                  NOT16_MM, OR16_MM, OR_MM, ORi_MM, ROTRV_MM,
 | |
|                                  ROTR_MM, SEB_MM, SEH_MM, SLL16_MM, SLLV_MM,
 | |
|                                  SLL_MM, SLT_MM, SLTi_MM, SLTiu_MM, SLTu_MM,
 | |
|                                  SRAV_MM, SRA_MM, SRL16_MM, SRLV_MM, SRL_MM,
 | |
|                                  SSNOP_MM, SUBU16_MM, SUB_MM, SUBu_MM,
 | |
|                                  WSBH_MM, XOR16_MM, XOR_MM, XORi_MM)>;
 | |
| 
 | |
| // microMIPS32r6
 | |
| // =============
 | |
| 
 | |
| def : InstRW<[GenericWriteALU], (instrs ADDIUPC_MMR6, ADDIU_MMR6, ADDU16_MMR6,
 | |
|                                  ADDU_MMR6, ADD_MMR6, ALIGN_MMR6, ALUIPC_MMR6,
 | |
|                                  AND16_MMR6, ANDI16_MMR6, ANDI_MMR6, AND_MMR6,
 | |
|                                  AUIPC_MMR6, AUI_MMR6, BITSWAP_MMR6, CLO_MMR6,
 | |
|                                  CLZ_MMR6, EXT_MMR6, INS_MMR6, LI16_MMR6,
 | |
|                                  LSA_MMR6, LUI_MMR6, MOVE16_MMR6, NOR_MMR6,
 | |
|                                  NOT16_MMR6, OR16_MMR6, ORI_MMR6, OR_MMR6,
 | |
|                                  SELEQZ_MMR6, SELNEZ_MMR6, SLL16_MMR6,
 | |
|                                  SLL_MMR6, SRL16_MMR6, SSNOP_MMR6, SUBU16_MMR6,
 | |
|                                  SUBU_MMR6, SUB_MMR6, WSBH_MMR6, XOR16_MMR6,
 | |
| 										             XORI_MMR6, XOR_MMR6)>;
 | |
| 
 | |
| // MIPS64
 | |
| // ======
 | |
| 
 | |
| def : InstRW<[GenericWriteALU], (instrs AND64, ANDi64, DEXT64_32, DSLL64_32,
 | |
|                                  ORi64, SEB64, SEH64, SLL64_32, SLL64_64,
 | |
|                                  SLT64, SLTi64, SLTiu64, SLTu64, XOR64,
 | |
|                                  XORi64)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteALU], (instrs DADD, DADDi, DADDiu, DADDu, DCLO,
 | |
|                                  DCLZ, DEXT, DEXTM, DEXTU, DINS, DINSM, DINSU,
 | |
|                                  DROTR, DROTR32, DROTRV, DSBH, DSHD, DSLL,
 | |
|                                  DSLL32, DSLLV, DSRA, DSRA32, DSRAV, DSRL,
 | |
|                                  DSRL32, DSRLV, DSUB, DSUBu, LEA_ADDiu64,
 | |
|                                  LUi64, NOR64, OR64)>;
 | |
| 
 | |
| // MIPS64R6
 | |
| // ========
 | |
| 
 | |
| def : InstRW<[GenericWriteALU], (instrs DALIGN, DAHI, DATI, DAUI, DCLO_R6,
 | |
|                                  DCLZ_R6, DBITSWAP, DLSA, DLSA_R6, SELEQZ64,
 | |
|                                  SELNEZ64)>;
 | |
| 
 | |
| 
 | |
| def GenericMDU : ProcResource<1> { let BufferSize = 1; }
 | |
| def GenericIssueMDU : ProcResource<1> { let Super = GenericALU; }
 | |
| def GenericIssueDIV : ProcResource<1> { let Super = GenericMDU; }
 | |
| def GenericWriteHILO : SchedWriteRes<[GenericIssueMDU]>;
 | |
| def GenericWriteALULong : SchedWriteRes<[GenericIssueALU]> { let Latency = 5; }
 | |
| def GenericWriteMove : SchedWriteRes<[GenericIssueALU]> { let Latency = 2; }
 | |
| def GenericWriteMul : SchedWriteRes<[GenericIssueMDU]> { let Latency = 4; }
 | |
| 
 | |
| def : InstRW<[GenericWriteHILO], (instrs MADD, MADDU, MSUB, MSUBU)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteHILO], (instrs PseudoMADD_MM, PseudoMADDU_MM,
 | |
|                                   PseudoMSUB_MM, PseudoMSUBU_MM,
 | |
|                                   PseudoMULT_MM, PseudoMULTu_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteHILO], (instrs PseudoMADD, PseudoMADDU, PseudoMSUB,
 | |
|                                   PseudoMSUBU, PseudoMULT, PseudoMULTu)>;
 | |
| 
 | |
| def GenericWriteMDUtoGPR : SchedWriteRes<[GenericIssueMDU]> {
 | |
|   let Latency = 5;
 | |
| }
 | |
| 
 | |
| def GenericWriteDIV : SchedWriteRes<[GenericIssueDIV]> {
 | |
|   // Estimated worst case
 | |
|   let Latency = 33;
 | |
|   let ResourceCycles = [33];
 | |
| }
 | |
| def GenericWriteDIVU : SchedWriteRes<[GenericIssueDIV]> {
 | |
|   // Estimated worst case
 | |
|   let Latency = 31;
 | |
|   let ResourceCycles = [31];
 | |
| }
 | |
| 
 | |
| // mul
 | |
| def : InstRW<[GenericWriteMDUtoGPR], (instrs MUL)>;
 | |
| 
 | |
| // mult, multu
 | |
| def : InstRW<[GenericWriteMul], (instrs MULT, MULTu)>;
 | |
| 
 | |
| // div, sdiv
 | |
| def : InstRW<[GenericWriteDIV], (instrs PseudoSDIV, SDIV)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteDIVU], (instrs PseudoUDIV, UDIV)>;
 | |
| 
 | |
| // mfhi, mflo, movn, mthi, mtlo, rdwhr
 | |
| def : InstRW<[GenericWriteALULong], (instrs MFHI, MFLO, PseudoMFHI,
 | |
|                                      PseudoMFLO)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteALULong], (instrs PseudoMFHI_MM, PseudoMFLO_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteMove], (instrs MTHI, MTLO, RDHWR, PseudoMTLOHI)>;
 | |
| def : InstRW<[GenericWriteMove], (instrs PseudoMTLOHI_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteALU], (instrs MOVN_I_I, MOVZ_I_I)>;
 | |
| 
 | |
| // MIPSR6
 | |
| // ======
 | |
| 
 | |
| // muh, muhu, mulu, mul
 | |
| def : InstRW<[GenericWriteMul], (instrs MUH, MUHU, MULU, MUL_R6)>;
 | |
| 
 | |
| // divu, udiv
 | |
| def : InstRW<[GenericWriteDIV], (instrs MOD, MODU, DIV, DIVU)>;
 | |
| 
 | |
| 
 | |
| // MIPS16e
 | |
| // =======
 | |
| 
 | |
| def : InstRW<[GenericWriteHILO], (instrs MultRxRy16, MultuRxRy16,
 | |
|                                   MultRxRyRz16, MultuRxRyRz16)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteDIV], (instrs DivRxRy16)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteDIVU], (instrs DivuRxRy16)>;
 | |
| 
 | |
| // microMIPS
 | |
| // =========
 | |
| 
 | |
| def : InstRW<[GenericWriteMul], (instrs MULT_MM, MULTu_MM, MADD_MM, MADDU_MM,
 | |
|                                  MSUB_MM, MSUBU_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteALULong], (instrs MUL_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteDIV], (instrs SDIV_MM, SDIV_MM_Pseudo)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteDIVU], (instrs UDIV_MM, UDIV_MM_Pseudo)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteMove], (instrs MFHI16_MM, MFLO16_MM, MOVF_I_MM,
 | |
|                                   MOVT_I_MM, MFHI_MM, MFLO_MM, MTHI_MM,
 | |
|                                   MTLO_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteMove], (instrs RDHWR_MM)>;
 | |
| 
 | |
| // microMIPS32r6
 | |
| // =============
 | |
| 
 | |
| def : InstRW<[GenericWriteMul], (instrs MUHU_MMR6, MUH_MMR6, MULU_MMR6,
 | |
|                                  MUL_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteDIV], (instrs MODU_MMR6, MOD_MMR6, DIVU_MMR6,
 | |
|                                  DIV_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteMove], (instrs RDHWR_MMR6)>;
 | |
| 
 | |
| // MIPS64
 | |
| // ======
 | |
| 
 | |
| def : InstRW<[GenericWriteHILO], (instrs DMULU, DMULT, DMULTu, PseudoDMULT,
 | |
|                                   PseudoDMULTu)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteDIV], (instrs DSDIV, PseudoDSDIV)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteDIVU], (instrs DUDIV, PseudoDUDIV)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteALULong], (instrs MFHI64, MFLO64, PseudoMFHI64,
 | |
|                                      PseudoMFLO64, PseudoMTLOHI64)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteMove], (instrs MTHI64, MTLO64, RDHWR64)>;
 | |
| 
 | |
| // mov[zn]
 | |
| def : InstRW<[GenericWriteALU], (instrs MOVN_I_I64, MOVN_I64_I, MOVN_I64_I64,
 | |
|                                  MOVZ_I_I64, MOVZ_I64_I, MOVZ_I64_I64)>;
 | |
| 
 | |
| 
 | |
| // MIPS64R6
 | |
| // ========
 | |
| 
 | |
| def : InstRW<[GenericWriteMDUtoGPR], (instrs DMUH, DMUHU, DMUL_R6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteDIV], (instrs DDIV, DMOD)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteDIVU], (instrs DDIVU, DMODU)>;
 | |
| 
 | |
| // CTISTD Pipeline
 | |
| // ---------------
 | |
| 
 | |
| def GenericIssueCTISTD : ProcResource<1> { let Super = GenericALU; }
 | |
| 
 | |
| def GenericLDST : ProcResource<1> { let BufferSize = 1; }
 | |
| def GenericIssueLDST : ProcResource<1> { let Super = GenericLDST; }
 | |
| 
 | |
| def GenericWriteJump : SchedWriteRes<[GenericIssueCTISTD]>;
 | |
| def GenericWriteJumpAndLink : SchedWriteRes<[GenericIssueCTISTD]> {
 | |
|   let Latency = 2;
 | |
| }
 | |
| 
 | |
| // b, beq, beql, bg[et]z, bl[et]z, bne, bnel, j, syscall, jal, bltzal, jalx,
 | |
| // jalr, jr.hb, jr, jalr.hb, jarlc, jialc
 | |
| def : InstRW<[GenericWriteJump], (instrs B, BAL, BAL_BR, BEQ, BNE, BGTZ, BGEZ,
 | |
|                                   BLEZ, BLTZ, BLTZAL, J, JALX, JR, JR_HB, ERET,
 | |
|                                   ERet, ERETNC, DERET)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteJump], (instrs BEQL, BNEL, BGEZL, BGTZL, BLEZL,
 | |
|                                   BLTZL)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteJump], (instrs TAILCALL, TAILCALLREG,
 | |
|                                   TAILCALLREGHB, PseudoIndirectBranch,
 | |
|                                   PseudoIndirectHazardBranch, PseudoReturn,
 | |
|                                   RetRA)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteJumpAndLink], (instrs BGEZAL, JAL, JALR, JALR_HB,
 | |
|                                          JALRHBPseudo, JALRPseudo)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteJumpAndLink], (instrs BGEZALL, BLTZALL)>;
 | |
| 
 | |
| def GenericWriteTrap : SchedWriteRes<[GenericIssueCTISTD]>;
 | |
| 
 | |
| def : InstRW<[GenericWriteTrap], (instrs BREAK, SYSCALL, TEQ, TEQI,
 | |
|                                   TGE, TGEI, TGEIU, TGEU, TNE,
 | |
|                                   TNEI, TLT, TLTI, TLTU, TTLTIU,
 | |
|                                   TRAP, SDBBP)>;
 | |
| 
 | |
| // MIPSR6
 | |
| // ======
 | |
| 
 | |
| def : InstRW<[GenericWriteJumpAndLink], (instrs BALC, BEQZALC, BGEZALC,
 | |
|                                          BGTZALC, BLEZALC, BLTZALC,
 | |
|                                          BNEZALC,
 | |
|                                          JIALC)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteJump], (instrs BC, BC2EQZ, BC2NEZ, BEQC, BEQZC, BGEC,
 | |
|                                   BGEUC, BGEZC, BGTZC, BLEZC, BLTC, BLTUC,
 | |
|                                   BLTZC, BNEC, BNEZC, BNVC, BOVC, JIC, JR_HB_R6,
 | |
|                                   SIGRIE, PseudoIndirectBranchR6,
 | |
|                                   PseudoIndrectHazardBranchR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteJump], (instrs TAILCALLR6REG, TAILCALLHBR6REG)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteTrap], (instrs SDBBP_R6)>;
 | |
| 
 | |
| // MIPS16e
 | |
| // =======
 | |
| 
 | |
| def : InstRW<[GenericWriteJump], (instrs Bimm16, BimmX16, BeqzRxImm16,
 | |
|                                   BeqzRxImmX16, BnezRxImm16, BnezRxImmX16,
 | |
|                                   Bteqz16, BteqzX16, BteqzT8CmpX16,
 | |
|                                   BteqzT8CmpiX16, BteqzT8SltX16,
 | |
|                                   BteqzT8SltuX16, BteqzT8SltiX16,
 | |
|                                   BteqzT8SltiuX16, Btnez16, BtnezX16,
 | |
|                                   BtnezT8CmpX16, BtnezT8CmpiX16,
 | |
|                                   BtnezT8SltX16, BtnezT8SltuX16,
 | |
|                                   BtnezT8SltiX16, BtnezT8SltiuX16, JrRa16,
 | |
|                                   JrcRa16, JrcRx16, RetRA16)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteJumpAndLink], (instrs Jal16, JalB16, JumpLinkReg16)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteTrap], (instrs Break16)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteALULong], (instrs SelBeqZ, SelTBteqZCmp,
 | |
|                                      SelTBteqZCmpi, SelTBteqZSlt,
 | |
|                                      SelTBteqZSlti, SelTBteqZSltu,
 | |
|                                      SelTBteqZSltiu, SelBneZ, SelTBtneZCmp,
 | |
|                                      SelTBtneZCmpi, SelTBtneZSlt,
 | |
|                                      SelTBtneZSlti, SelTBtneZSltu,
 | |
|                                      SelTBtneZSltiu)>;
 | |
| 
 | |
| // microMIPS
 | |
| // =========
 | |
| 
 | |
| def : InstRW<[GenericWriteJump], (instrs B16_MM, BAL_BR_MM, BC1F_MM, BC1T_MM,
 | |
|                                   BEQZ16_MM, BEQZC_MM, BEQ_MM, BGEZ_MM,
 | |
|                                   BGTZ_MM, BLEZ_MM, BLTZ_MM, BNEZ16_MM,
 | |
|                                   BNEZC_MM, BNE_MM, B_MM, DERET_MM, ERET_MM,
 | |
|                                   JR16_MM, JR_MM, J_MM, B_MM_Pseudo)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteJumpAndLink], (instrs BGEZALS_MM, BGEZAL_MM,
 | |
|                                          BLTZALS_MM, BLTZAL_MM, JALR16_MM,
 | |
|                                          JALRS16_MM, JALRS_MM, JALR_MM,
 | |
|                                          JALS_MM, JALX_MM, JAL_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteJump], (instrs TAILCALLREG_MM, TAILCALL_MM,
 | |
|                                   PseudoIndirectBranch_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteTrap], (instrs BREAK16_MM, BREAK_MM, SDBBP16_MM,
 | |
|                                   SDBBP_MM, SYSCALL_MM, TEQI_MM, TEQ_MM,
 | |
|                                   TGEIU_MM, TGEI_MM, TGEU_MM, TGE_MM, TLTIU_MM,
 | |
|                                   TLTI_MM, TLTU_MM, TLT_MM, TNEI_MM, TNE_MM,
 | |
|                                   TRAP_MM)>;
 | |
| 
 | |
| // microMIPS32r6
 | |
| // =============
 | |
| 
 | |
| def : InstRW<[GenericWriteJump], (instrs BC16_MMR6, BC1EQZC_MMR6, BC1NEZC_MMR6,
 | |
|                                   BC2EQZC_MMR6, BC2NEZC_MMR6, BC_MMR6,
 | |
|                                   BEQC_MMR6, BEQZC16_MMR6, BEQZC_MMR6,
 | |
|                                   BGEC_MMR6, BGEUC_MMR6, BGEZC_MMR6,
 | |
|                                   BGTZC_MMR6, BLEZC_MMR6, BLTC_MMR6,
 | |
|                                   BLTUC_MMR6, BLTZC_MMR6, BNEC_MMR6,
 | |
|                                   BNEZC16_MMR6, BNEZC_MMR6, BNVC_MMR6,
 | |
|                                   BOVC_MMR6, DERET_MMR6, ERETNC_MMR6, JAL_MMR6,
 | |
|                                   ERET_MMR6, JIC_MMR6, JRADDIUSP, JRC16_MM,
 | |
|                                   JRC16_MMR6, JRCADDIUSP_MMR6, SIGRIE_MMR6,
 | |
|                                   B_MMR6_Pseudo, PseudoIndirectBranch_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteJumpAndLink], (instrs BALC_MMR6, BEQZALC_MMR6,
 | |
|                                          BGEZALC_MMR6, BGTZALC_MMR6,
 | |
|                                          BLEZALC_MMR6, BLTZALC_MMR6,
 | |
|                                          BNEZALC_MMR6, JALRC16_MMR6,
 | |
|                                          JALRC_HB_MMR6, JALRC_MMR6,
 | |
|                                          JIALC_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteJump], (instrs TAILCALLREG_MMR6, TAILCALL_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteTrap], (instrs BREAK16_MMR6, BREAK_MMR6, SDBBP_MMR6,
 | |
|                                   SDBBP16_MMR6)>;
 | |
| 
 | |
| // MIPS64
 | |
| // ======
 | |
| 
 | |
| def : InstRW<[GenericWriteJump], (instrs BEQ64, BGEZ64, BGTZ64, BLEZ64,
 | |
|                                   BLTZ64, BNE64, JR64)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteJumpAndLink], (instrs JALR64, JALR64Pseudo,
 | |
|                                          JALRHB64Pseudo, JALR_HB64)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteJump], (instrs JR_HB64, TAILCALLREG64,
 | |
|                                   TAILCALLREGHB64, PseudoReturn64)>;
 | |
| 
 | |
| // MIPS64R6
 | |
| // ========
 | |
| 
 | |
| def : InstRW<[GenericWriteJump], (instrs BEQC64, BEQZC64, BGEC64, BGEUC64,
 | |
|                                   BGEZC64, BGTZC64, BLEZC64, BLTC64, BLTUC64,
 | |
|                                   BLTZC64, BNEC64, BNEZC64, JIC64,
 | |
|                                   PseudoIndirectBranch64,
 | |
|                                   PseudoIndirectHazardBranch64)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteJumpAndLink], (instrs JIALC64)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteJump], (instrs JR_HB64_R6, TAILCALL64R6REG,
 | |
|                                   TAILCALLHB64R6REG, PseudoIndirectBranch64R6,
 | |
|                                   PseudoIndrectHazardBranch64R6)>;
 | |
| 
 | |
| // COP0 Pipeline
 | |
| // =============
 | |
| 
 | |
| def GenericCOP0 : ProcResource<1> { let BufferSize = 1; }
 | |
| 
 | |
| def GenericIssueCOP0 : ProcResource<1> { let Super = GenericCOP0; }
 | |
| def GenericWriteCOP0TLB : SchedWriteRes<[GenericIssueCOP0]> { let Latency = 4; }
 | |
| def GenericWriteCOP0 : SchedWriteRes<[GenericIssueCOP0]> { let Latency = 3; }
 | |
| def GenericReadCOP0 : SchedWriteRes<[GenericIssueCOP0]> { let Latency = 2; }
 | |
| def GenericReadWritePGPR : SchedWriteRes<[GenericIssueCOP0]>;
 | |
| def GenericReadWriteCOP0Long : SchedWriteRes<[GenericIssueCOP0]> {
 | |
|   let Latency = 5;
 | |
| }
 | |
| def GenericWriteCOP0Short : SchedWriteRes<[GenericIssueCOP0]>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0TLB], (instrs TLBP, TLBR, TLBWI, TLBWR)>;
 | |
| def : InstRW<[GenericWriteCOP0TLB], (instrs TLBINV, TLBINVF)>;
 | |
| 
 | |
| def : InstRW<[GenericReadCOP0], (instrs MFC0)>;
 | |
| def : InstRW<[GenericWriteCOP0], (instrs MTC0)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0], (instrs EVP, DVP)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0], (instrs DI, EI)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0], (instrs EHB, PAUSE, WAIT)>;
 | |
| 
 | |
| // microMIPS
 | |
| // =========
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0TLB], (instrs TLBP_MM, TLBR_MM, TLBWI_MM,
 | |
|                                      TLBWR_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0], (instrs DI_MM, EI_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0], (instrs EHB_MM, PAUSE_MM, WAIT_MM)>;
 | |
| 
 | |
| 
 | |
| // microMIPS32R6
 | |
| // =============
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0], (instrs RDPGPR_MMR6, WRPGPR_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0TLB], (instrs TLBINV_MMR6, TLBINVF_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericReadCOP0], (instrs MFHC0_MMR6, MFC0_MMR6, MFHC2_MMR6,
 | |
|                                  MFC2_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0], (instrs MTHC0_MMR6, MTC0_MMR6, MTHC2_MMR6,
 | |
|                                   MTC2_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0], (instrs EVP_MMR6, DVP_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0], (instrs DI_MMR6, EI_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0], (instrs EHB_MMR6, PAUSE_MMR6, WAIT_MMR6)>;
 | |
| 
 | |
| // MIPS64
 | |
| // ======
 | |
| 
 | |
| def : InstRW<[GenericReadCOP0], (instrs DMFC0)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0], (instrs DMTC0)>;
 | |
| 
 | |
| 
 | |
| def GenericCOP2 : ProcResource<1> { let BufferSize = 1; }
 | |
| def GenericWriteCOPOther : SchedWriteRes<[GenericCOP2]>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCOPOther], (instrs MFC2, MTC2)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCOPOther], (instrs DMFC2, DMTC2)>;
 | |
| 
 | |
| // microMIPS32R6
 | |
| // =============
 | |
| 
 | |
| // The latency and repeat rate of these instructions are implementation
 | |
| // dependant.
 | |
| def : InstRW<[GenericWriteMove], (instrs CFC2_MM, CTC2_MM)>;
 | |
| 
 | |
| 
 | |
| // MIPS MT ASE - hasMT
 | |
| // ====================
 | |
| 
 | |
| def : InstRW<[GenericWriteMove], (instrs DMT, DVPE, EMT, EVPE, MFTR,
 | |
|                                   MTTR)>;
 | |
| 
 | |
| def : InstRW<[GenericReadWriteCOP0Long], (instrs YIELD)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0Short], (instrs FORK)>;
 | |
| 
 | |
| // MIPS Virtualization ASE
 | |
| // =======================
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0Short], (instrs HYPCALL, TLBGINV, TLBGINVF, TLBGP,
 | |
|                                        TLBGR, TLBGWI, TLBGWR, MFGC0, MFHGC0,
 | |
|                                        MTGC0, MTHGC0)>;
 | |
| 
 | |
| // MIPS64 Virtualization ASE
 | |
| // =========================
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0Short], (instrs DMFGC0, DMTGC0)>;
 | |
| 
 | |
| // microMIPS virtualization ASE
 | |
| // ============================
 | |
| 
 | |
| def : InstRW<[GenericWriteCOP0Short], (instrs HYPCALL_MM, TLBGINVF_MM,
 | |
|                                        TLBGINV_MM, TLBGP_MM, TLBGR_MM,
 | |
|                                        TLBGWI_MM, TLBGWR_MM, MFGC0_MM,
 | |
|                                        MFHGC0_MM, MTGC0_MM, MTHGC0_MM)>;
 | |
| 
 | |
| // LDST Pipeline
 | |
| // -------------
 | |
| 
 | |
| def GenericWriteLoad : SchedWriteRes<[GenericIssueLDST]> {
 | |
|   let Latency = 2;
 | |
| }
 | |
| 
 | |
| def GenericWritePref : SchedWriteRes<[GenericIssueLDST]>;
 | |
| def GenericWriteSync : SchedWriteRes<[GenericIssueLDST]>;
 | |
| def GenericWriteCache : SchedWriteRes<[GenericIssueLDST]> { let Latency = 5; }
 | |
| 
 | |
| def GenericWriteStore : SchedWriteRes<[GenericIssueLDST]>;
 | |
| def GenericWriteStoreSC : SchedWriteRes<[GenericIssueLDST]> { let Latency = 2; }
 | |
| 
 | |
| def GenericWriteGPRFromBypass : SchedWriteRes<[GenericIssueLDST]> {
 | |
|   let Latency = 2;
 | |
| }
 | |
| 
 | |
| def GenericWriteStoreFromOtherUnits : SchedWriteRes<[GenericIssueLDST]>;
 | |
| def GenericWriteLoadToOtherUnits : SchedWriteRes<[GenericIssueLDST]> {
 | |
|   let Latency = 0;
 | |
| }
 | |
| 
 | |
| // l[bhw], l[bh]u, ll
 | |
| def : InstRW<[GenericWriteLoad], (instrs LB, LBu, LH, LHu, LW, LL,
 | |
|                                   LWC2, LWC3, LDC2, LDC3)>;
 | |
| 
 | |
| // lw[lr]
 | |
| def : InstRW<[GenericWriteLoad], (instrs LWL, LWR)>;
 | |
| 
 | |
| // s[bhw], sc, s[dw]c[23]
 | |
| def : InstRW<[GenericWriteStore], (instrs SB, SH, SW, SWC2, SWC3,
 | |
|                                    SDC2, SDC3)>;
 | |
| 
 | |
| // PreMIPSR6 sw[lr]
 | |
| def : InstRW<[GenericWriteStore], (instrs SWL, SWR)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteStoreSC], (instrs SC, SC_MMR6)>;
 | |
| 
 | |
| // pref
 | |
| def : InstRW<[GenericWritePref], (instrs PREF)>;
 | |
| // cache
 | |
| def : InstRW<[GenericWriteCache], (instrs CACHE)>;
 | |
| 
 | |
| // sync
 | |
| def : InstRW<[GenericWriteSync], (instrs SYNC, SYNCI)>;
 | |
| 
 | |
| // MIPSR6
 | |
| // ======
 | |
| 
 | |
| def : InstRW<[GenericWriteLoad], (instrs LDC2_R6, LL_R6, LWC2_R6, LWPC)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteStore], (instrs SWC2_R6,  SDC2_R6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteStoreSC], (instrs SC_R6)>;
 | |
| 
 | |
| def : InstRW<[GenericWritePref], (instrs PREF_R6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCache], (instrs CACHE_R6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteSync], (instrs GINVI, GINVT)>;
 | |
| 
 | |
| // MIPS32 EVA
 | |
| // ==========
 | |
| 
 | |
| def : InstRW<[GenericWriteLoad], (instrs LBE, LBuE, LHE, LHuE, LWE,
 | |
|                                   LLE)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteStore], (instrs SBE, SHE, SWE, SCE)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteLoad], (instrs LWLE, LWRE)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteStore], (instrs SWLE, SWRE)>;
 | |
| 
 | |
| def : InstRW<[GenericWritePref], (instrs PREFE)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCache], (instrs CACHEE)>;
 | |
| 
 | |
| // microMIPS EVA ASE - InMicroMipsMode, hasEVA
 | |
| // ===========================================
 | |
| 
 | |
| def : InstRW<[GenericWriteLoad], (instrs LBE_MM, LBuE_MM, LHE_MM, LHuE_MM,
 | |
|                                   LWE_MM, LWLE_MM, LWRE_MM, LLE_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteStore], (instrs SBE_MM, SB_MM, SHE_MM, SWE_MM,
 | |
|                                    SWLE_MM, SWRE_MM, SCE_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWritePref], (instrs PREFE_MM)>;
 | |
| def : InstRW<[GenericWriteCache], (instrs CACHEE_MM)>;
 | |
| 
 | |
| 
 | |
| // MIPS16e
 | |
| // =======
 | |
| 
 | |
| def : InstRW<[GenericWriteLoad], (instrs Restore16, RestoreX16,
 | |
|                                   LbRxRyOffMemX16,
 | |
|                                   LbuRxRyOffMemX16, LhRxRyOffMemX16,
 | |
|                                   LhuRxRyOffMemX16, LwRxRyOffMemX16,
 | |
|                                   LwRxSpImmX16, LwRxPcTcp16, LwRxPcTcpX16)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteStore], (instrs Save16, SaveX16, SbRxRyOffMemX16,
 | |
|                                    ShRxRyOffMemX16, SwRxRyOffMemX16,
 | |
|                                    SwRxSpImmX16)>;
 | |
| 
 | |
| // microMIPS
 | |
| // =========
 | |
| 
 | |
| def : InstRW<[GenericWriteLoad], (instrs LBU16_MM, LB_MM, LBu_MM, LHU16_MM,
 | |
|                                   LH_MM, LHu_MM, LL_MM, LW16_MM, LWGP_MM,
 | |
|                                   LWL_MM, LWM16_MM, LWM32_MM, LWP_MM, LWR_MM,
 | |
|                                   LWSP_MM, LWU_MM, LWXS_MM, LW_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteStore], (instrs SB16_MM, SC_MM, SH16_MM, SH_MM,
 | |
|                                    SW16_MM, SWL_MM, SWM16_MM, SWM32_MM, SWM_MM,
 | |
|                                    SWP_MM, SWR_MM, SWSP_MM, SW_MM)>;
 | |
| 
 | |
| 
 | |
| def : InstRW<[GenericWritePref], (instrs PREF_MM, PREFX_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCache], (instrs CACHE_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteSync], (instrs SYNC_MM, SYNCI_MM)>;
 | |
| def : InstRW<[GenericWriteSync], (instrs GINVI_MMR6, GINVT_MMR6)>;
 | |
| 
 | |
| // microMIPS32r6
 | |
| // =============
 | |
| 
 | |
| def : InstRW<[GenericWriteLoad], (instrs LBU_MMR6, LB_MMR6, LDC2_MMR6, LL_MMR6,
 | |
|                                   LWM16_MMR6, LWC2_MMR6, LWPC_MMR6, LW_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteStore], (instrs SB16_MMR6, SB_MMR6, SDC2_MMR6,
 | |
|                                    SH16_MMR6, SH_MMR6, SW16_MMR6, SWC2_MMR6,
 | |
|                                    SWM16_MMR6, SWSP_MMR6, SW_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteSync], (instrs SYNC_MMR6, SYNCI_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWritePref], (instrs PREF_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteCache], (instrs CACHE_MMR6)>;
 | |
| 
 | |
| // MIPS64
 | |
| // ======
 | |
| 
 | |
| def : InstRW<[GenericWriteLoad], (instrs LD, LL64, LLD, LWu, LB64, LBu64,
 | |
|                                   LH64, LHu64, LW64)>;
 | |
| 
 | |
| // l[dw][lr]
 | |
| def : InstRW<[GenericWriteLoad], (instrs LWL64, LWR64, LDL, LDR)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteStore], (instrs SD, SC64, SCD, SB64, SH64, SW64,
 | |
|                                    SWL64, SWR64)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteStore], (instrs SDL, SDR)>;
 | |
| 
 | |
| // MIPS64R6
 | |
| // ========
 | |
| 
 | |
| def : InstRW<[GenericWriteLoad], (instrs LWUPC, LDPC)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteLoad], (instrs LLD_R6, LL64_R6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteStoreSC], (instrs SC64_R6, SCD_R6)>;
 | |
| 
 | |
| // MIPSR6 CRC ASE - hasCRC
 | |
| // =======================
 | |
| 
 | |
| def : InstRW<[GenericWriteALU], (instrs CRC32B, CRC32H, CRC32W, CRC32CB,
 | |
|                                  CRC32CH, CRC32CW)>;
 | |
| 
 | |
| // MIPS64R6 CRC ASE - hasCRC
 | |
| // -------------------------
 | |
| 
 | |
| def : InstRW<[GenericWriteALU], (instrs CRC32D, CRC32CD)>;
 | |
| 
 | |
| 
 | |
| // Cavium Networks MIPS (cnMIPS) - Octeon, HasCnMips
 | |
| // =================================================
 | |
| 
 | |
| def : InstRW<[GenericWriteALU], (instrs BADDu, BBIT0, BBIT032, BBIT1, BBIT132,
 | |
|                                  CINS, CINS32, CINS64_32, CINS_i32,
 | |
|                                  DMFC2_OCTEON, DMTC2_OCTEON, DPOP, EXTS,
 | |
|                                  EXTS32, MTM0, MTM1, MTM2, MTP0, MTP1, MTP2,
 | |
|                                  POP, SEQ, SEQi, SNE, SNEi,
 | |
|                                  V3MULU, VMM0, VMULU)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteMDUtoGPR], (instrs DMUL)>;
 | |
| 
 | |
| // Cavium Networks MIPS (cnMIPSP) - Octeon+, HasCnMipsP
 | |
| // =================================================
 | |
| 
 | |
| def : InstRW<[GenericWriteALU], (instrs SAA, SAAD)>;
 | |
| 
 | |
| // FPU Pipelines
 | |
| // =============
 | |
| 
 | |
| def GenericFPQ : ProcResource<1> { let BufferSize = 1; }
 | |
| def GenericIssueFPUS : ProcResource<1> { let Super = GenericFPQ; }
 | |
| def GenericIssueFPUL : ProcResource<1> { let Super = GenericFPQ; }
 | |
| def GenericIssueFPULoad : ProcResource<1> { let Super = GenericFPQ; }
 | |
| def GenericIssueFPUStore : ProcResource<1> { let Super = GenericFPQ; }
 | |
| def GenericIssueFPUMove : ProcResource<1> { let Super = GenericFPQ; }
 | |
| def GenericFPUDivSqrt : ProcResource<1> { let Super = GenericFPQ; }
 | |
| 
 | |
| // The floating point compare of the 24k series including interAptiv has a
 | |
| // listed latency of 1-2. Using the higher latency here.
 | |
| 
 | |
| def GenericWriteFPUCmp : SchedWriteRes<[GenericIssueFPUS]> { let Latency = 2; }
 | |
| def GenericWriteFPUS : SchedWriteRes<[GenericIssueFPUS]> { let Latency = 4; }
 | |
| def GenericWriteFPUL : SchedWriteRes<[GenericIssueFPUL]> { let Latency = 5; }
 | |
| def GenericWriteFPUStore : SchedWriteRes<[GenericIssueFPUStore]> { let
 | |
|   Latency = 1;
 | |
| }
 | |
| def GenericWriteFPULoad : SchedWriteRes<[GenericIssueFPULoad]> {
 | |
|   let Latency = 2;
 | |
| }
 | |
| def GenericWriteFPUMoveFP : SchedWriteRes<[GenericIssueFPUMove]> {
 | |
|   let Latency = 4;
 | |
| }
 | |
| def GenericWriteFPUMoveGPRFPU : SchedWriteRes<[GenericIssueFPUMove]> {
 | |
|   let Latency = 2;
 | |
| }
 | |
| def GenericWriteFPUDivS : SchedWriteRes<[GenericFPUDivSqrt]> {
 | |
|   let Latency = 17;
 | |
|   let ResourceCycles = [ 14 ];
 | |
| }
 | |
| def GenericWriteFPUDivD : SchedWriteRes<[GenericFPUDivSqrt]> {
 | |
|   let Latency = 32;
 | |
|   let ResourceCycles = [ 29 ];
 | |
| }
 | |
| def GenericWriteFPURcpS : SchedWriteRes<[GenericFPUDivSqrt]> {
 | |
|   let Latency = 13;
 | |
|   let ResourceCycles = [ 10 ];
 | |
| }
 | |
| def GenericWriteFPURcpD : SchedWriteRes<[GenericFPUDivSqrt]> {
 | |
|   let Latency = 25;
 | |
|   let ResourceCycles = [ 21 ];
 | |
| }
 | |
| def GenericWriteFPURsqrtS : SchedWriteRes<[GenericFPUDivSqrt]> {
 | |
|   let Latency = 17;
 | |
|   let ResourceCycles = [ 14 ];
 | |
| }
 | |
| def GenericWriteFPURsqrtD : SchedWriteRes<[GenericFPUDivSqrt]> {
 | |
|   let Latency = 32;
 | |
|   let ResourceCycles = [ 29 ];
 | |
| }
 | |
| def GenericWriteFPUSqrtS : SchedWriteRes<[GenericFPUDivSqrt]> {
 | |
|   let Latency = 17;
 | |
|   let ResourceCycles = [ 14 ];
 | |
| }
 | |
| def GenericWriteFPUSqrtD : SchedWriteRes<[GenericFPUDivSqrt]> {
 | |
|   let Latency = 29;
 | |
|   let ResourceCycles = [ 29 ];
 | |
| }
 | |
| 
 | |
| // Floating point compare and branch
 | |
| // ---------------------------------
 | |
| //
 | |
| // c.<cc>.[ds], bc1[tf], bc1[tf]l
 | |
| def : InstRW<[GenericWriteFPUCmp], (instrs FCMP_D32, FCMP_D64, FCMP_S32, BC1F,
 | |
|                                     BC1T, BC1FL, BC1TL)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUCmp], (instregex "C_[A-Z]+_(S|D32|D64)$")>;
 | |
| 
 | |
| // Short Pipe
 | |
| // ----------
 | |
| //
 | |
| // abs.[ds], abs.ps, add.[ds], neg.[ds], neg.ps, madd.s, msub.s, nmadd,s
 | |
| // nmsub.s, sub.[ds], mul.s
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUS], (instrs FABS_S, FABS_D32, FABS_D64, FADD_D32,
 | |
|                                   FADD_D64, FADD_S, MADD_S, MSUB_S, FMUL_S,
 | |
|                                   FNEG_S, FNEG_D32, FNEG_D64, NMADD_S, NMSUB_S,
 | |
|                                   FSUB_S, FSUB_D32, FSUB_D64)>;
 | |
| 
 | |
| // Long Pipe
 | |
| // ----------
 | |
| //
 | |
| // nmadd.d, nmsub.d, mul.[ds], mul.ps, ceil.[wl].[sd], cvt.d.[sw], cvt.s.[dw],
 | |
| // cvt.w.[sd], cvt.[sw].ps, trunc.w.[ds], trunc.w.ps, floor.[ds],
 | |
| // round.[lw].[ds], floor.[lw].ds
 | |
| 
 | |
| // madd.d, msub.dm mul.d, mul.ps, nmadd.d, nmsub.d, ceil.[wl].[sd], cvt.d.[sw],
 | |
| // cvt.s.[dw], cvt.w.[sd], cvt.[sw].ps, round.[lw].[ds], floor.[lw].ds,
 | |
| // trunc.w.[ds], trunc.w.ps,
 | |
| def : InstRW<[GenericWriteFPUL], (instrs ADDR_PS64,
 | |
|                                   CEIL_L_D64, CEIL_L_S, CEIL_W_D32,
 | |
|                                   CEIL_W_D64, CEIL_W_S, CVT_D32_S, CVT_D32_W,
 | |
|                                   CVT_D64_L, CVT_D64_S, CVT_D64_W, CVT_L_D64,
 | |
|                                   CVT_L_S, CVT_S_D32, CVT_S_D64, CVT_S_L,
 | |
|                                   CVT_S_W, CVT_W_D32, CVT_W_D64, CVT_W_S,
 | |
|                                   CVT_PS_S64, CVT_S_PL64, CVT_S_PU64,
 | |
|                                   CVT_PS_PW64, CVT_PW_PS64, FADD_PS64,
 | |
|                                   FLOOR_L_D64, FLOOR_L_S, FLOOR_W_D32,
 | |
|                                   FLOOR_W_D64, FLOOR_W_S, FMUL_D32, FMUL_D64,
 | |
|                                   FMUL_PS64, FSUB_PS64, MADD_D32, MADD_D64,
 | |
|                                   MSUB_D32, MSUB_D64, MULR_PS64,
 | |
|                                   NMADD_D32, NMADD_D64, NMSUB_D32, NMSUB_D64,
 | |
|                                   PLL_PS64, PLU_PS64, PUL_PS64, PUU_PS64,
 | |
|                                   ROUND_L_D64, ROUND_L_S, ROUND_W_D32,
 | |
|                                   ROUND_W_D64, ROUND_W_S, TRUNC_L_D64,
 | |
|                                   TRUNC_L_S, TRUNC_W_D32, TRUNC_W_D64,
 | |
|                                   TRUNC_W_S, PseudoTRUNC_W_D,
 | |
|                                   PseudoTRUNC_W_D32, PseudoTRUNC_W_S)>;
 | |
| 
 | |
| // Pseudo convert instruction
 | |
| def : InstRW<[GenericWriteFPUL], (instrs PseudoCVT_D32_W, PseudoCVT_D64_L,
 | |
|                                   PseudoCVT_D64_W, PseudoCVT_S_L,
 | |
|                                   PseudoCVT_S_W)>;
 | |
| 
 | |
| // div.[ds], div.ps
 | |
| def : InstRW<[GenericWriteFPUDivS], (instrs FDIV_S)>;
 | |
| def : InstRW<[GenericWriteFPUDivD], (instrs FDIV_D32, FDIV_D64)>;
 | |
| 
 | |
| // sqrt.[ds], sqrt.ps
 | |
| def : InstRW<[GenericWriteFPUSqrtS], (instrs FSQRT_S)>;
 | |
| def : InstRW<[GenericWriteFPUSqrtD], (instrs FSQRT_D32, FSQRT_D64)>;
 | |
| 
 | |
| // rsqrt.[ds], recip.[ds]
 | |
| def : InstRW<[GenericWriteFPURcpS], (instrs RECIP_S, RSQRT_S)>;
 | |
| def : InstRW<[GenericWriteFPURcpD], (instrs RECIP_D32, RECIP_D64,
 | |
|                                      RSQRT_D32, RSQRT_D64)>;
 | |
| 
 | |
| 
 | |
| // Load Pipe
 | |
| // ---------
 | |
| 
 | |
| // ctc1, mtc1, mthc1, cfc1, mfc1, mfhc1
 | |
| def : InstRW<[GenericWriteFPUMoveGPRFPU], (instrs BuildPairF64,
 | |
|                                            BuildPairF64_64, ExtractElementF64,
 | |
|                                            ExtractElementF64_64, CFC1, CTC1,
 | |
|                                            MFC1, MFC1_D64, MFHC1_D32,
 | |
|                                            MFHC1_D64, MTC1, MTC1_D64,
 | |
|                                            MTHC1_D32, MTHC1_D64)>;
 | |
| 
 | |
| // swc1, swxc1
 | |
| def : InstRW<[GenericWriteFPUStore], (instrs SDC1, SDC164, SDXC1, SDXC164,
 | |
|                                       SUXC1, SUXC164, SWC1, SWXC1)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUMoveFP], (instrs FMOV_D32, FMOV_D64, FMOV_S)>;
 | |
| 
 | |
| 
 | |
| // movn.[ds], movz.[ds]
 | |
| def : InstRW<[GenericWriteFPUMoveFP], (instrs MOVF_I, MOVF_D32, MOVF_D64,
 | |
|                                        MOVF_S, MOVT_I, MOVT_D32, MOVT_D64,
 | |
|                                        MOVT_S, MOVN_I_D32, MOVN_I_D64,
 | |
|                                        MOVN_I_S, MOVZ_I_D32, MOVZ_I_D64,
 | |
|                                        MOVZ_I_S)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUMoveFP], (instrs MOVT_I64, MOVF_I64, MOVZ_I64_S,
 | |
|                                        MOVN_I64_D64, MOVN_I64_S,
 | |
|                                        MOVZ_I64_D64)>;
 | |
| 
 | |
| // l[dw]x?c1
 | |
| def : InstRW<[GenericWriteFPULoad], (instrs LDC1, LDC164, LDXC1, LDXC164,
 | |
|                                      LUXC1, LUXC164, LWC1, LWXC1)>;
 | |
| 
 | |
| // MIPSR6
 | |
| // ======
 | |
| 
 | |
| // sel(eq|ne).[ds], max.[ds], maxa.[ds], min.[ds], mina.[ds], class.[ds]
 | |
| def : InstRW<[GenericWriteFPUS], (instrs SELEQZ_S, SELNEZ_S, SELEQZ_D, SELNEZ_D,
 | |
|                                   MAX_S, MAX_D, MAXA_S, MAXA_D, MIN_S, MIN_D,
 | |
|                                   MINA_S, MINA_D, CLASS_S, CLASS_D)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUL], (instrs RINT_S, RINT_D)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUCmp], (instrs BC1EQZ, BC1NEZ, SEL_D, SEL_S)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUS], (instrs MADDF_S, MSUBF_S, MADDF_D, MSUBF_D)>;
 | |
| 
 | |
| 
 | |
| // microMIPS
 | |
| // =========
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUMoveFP], (instrs MOVF_D32_MM, MOVF_S_MM,
 | |
|                                        MOVN_I_D32_MM, MOVN_I_S_MM,
 | |
|                                        MOVT_D32_MM, MOVT_S_MM, MOVZ_I_D32_MM,
 | |
|                                        MOVZ_I_S_MM)>;
 | |
| 
 | |
| 
 | |
| //  cvt.?.?, ceil.?, floor.?, round.?, trunc.? (n)madd.? (n)msub.?
 | |
| def : InstRW<[GenericWriteFPUL], (instrs CVT_D32_S_MM, CVT_D32_W_MM,
 | |
|                                   CVT_D64_S_MM, CVT_D64_W_MM, CVT_L_D64_MM,
 | |
|                                   CVT_L_S_MM, CVT_S_D32_MM, CVT_S_D64_MM,
 | |
|                                   CVT_S_W_MM, CVT_W_D32_MM, CVT_W_D64_MM,
 | |
|                                   CVT_W_S_MM, CEIL_W_MM, CEIL_W_S_MM,
 | |
|                                   FLOOR_W_MM, FLOOR_W_S_MM, NMADD_S_MM,
 | |
|                                   NMADD_D32_MM, NMSUB_S_MM, NMSUB_D32_MM,
 | |
|                                   MADD_S_MM, MADD_D32_MM, ROUND_W_MM,
 | |
|                                   ROUND_W_S_MM, TRUNC_W_MM, TRUNC_W_S_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUCmp], (instregex "^C_[A-Z]_(S|D32|D64)_MM$")>;
 | |
| def : InstRW<[GenericWriteFPUCmp], (instregex "^C_[A-Z][A-Z]_(S|D32|D64)_MM$")>;
 | |
| def : InstRW<[GenericWriteFPUCmp], (instregex "^C_[A-Z][A-Z][A-Z]_(S|D32|D64)_MM$")>;
 | |
| def : InstRW<[GenericWriteFPUCmp], (instregex "^C_NGLE_(S|D32|D64)_MM$")>;
 | |
| def : InstRW<[GenericWriteFPUCmp], (instrs FCMP_S32_MM, FCMP_D32_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUS], (instrs MFC1_MM, MFHC1_D32_MM, MFHC1_D64_MM,
 | |
|                                   MTC1_MM, MTC1_D64_MM,
 | |
|                                   MTHC1_D32_MM, MTHC1_D64_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUS], (instrs FABS_D32_MM, FABS_D64_MM, FABS_S_MM,
 | |
|                                   FNEG_D32_MM, FNEG_D64_MM, FNEG_S_MM,
 | |
|                                   FADD_D32_MM, FADD_D64_MM, FADD_S_MM,
 | |
|                                   FMOV_D32_MM, FMOV_D64_MM, FMOV_S_MM,
 | |
|                                   FMUL_D32_MM, FMUL_D64_MM, FMUL_S_MM,
 | |
|                                   FSUB_D32_MM, FSUB_D64_MM, FSUB_S_MM,
 | |
|                                   MSUB_S_MM, MSUB_D32_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUDivS], (instrs FDIV_S_MM)>;
 | |
| def : InstRW<[GenericWriteFPUDivD], (instrs FDIV_D32_MM, FDIV_D64_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUSqrtS], (instrs FSQRT_S_MM)>;
 | |
| def : InstRW<[GenericWriteFPUSqrtD], (instrs FSQRT_D32_MM, FSQRT_D64_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPURcpS], (instrs RECIP_S_MM, RSQRT_S_MM)>;
 | |
| def : InstRW<[GenericWriteFPURcpD], (instrs RECIP_D32_MM, RECIP_D64_MM,
 | |
|                                      RSQRT_D32_MM, RSQRT_D64_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUStore], (instrs SDC1_MM, SWC1_MM, SUXC1_MM,
 | |
|                                       SWXC1_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUMoveGPRFPU], (instrs CFC1_MM, CTC1_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPULoad], (instrs LDC1_MM, LUXC1_MM, LWC1_MM,
 | |
|                                      LWXC1_MM)>;
 | |
| 
 | |
| // microMIPS32r6
 | |
| // =============
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUS], (instrs FNEG_S_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUCmp], (instregex "CMP_[A-Z][A-Z]_(S|D)_MMR6")>;
 | |
| def : InstRW<[GenericWriteFPUCmp],
 | |
|              (instregex "CMP_[A-Z][A-Z][A-Z]_(S|D)_MMR6")>;
 | |
| def : InstRW<[GenericWriteFPUCmp],
 | |
|              (instregex "CMP_[A-Z][A-Z][A-Z][A-Z]_(S|D)_MMR6")>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUL],
 | |
|              (instregex "CVT_(L|D|S|W)_(L|D|S|L|W)_MMR6")>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUL],
 | |
|              (instregex "TRUNC_(L|W)_(D|S)_MMR6")>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUL],
 | |
|              (instregex "ROUND_(L|W)_(D|S)_MMR6")>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUL],
 | |
|              (instregex "FLOOR_(L|W)_(D|S)_MMR6")>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUL],
 | |
|              (instregex "CEIL_(L|W)_(S|D)_MMR6")>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUS],
 | |
|              (instrs MFC1_MMR6, MTC1_MMR6, CLASS_S_MMR6, CLASS_D_MMR6,
 | |
|               FADD_S_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "M(IN|AX)_(S|D)_MMR6")>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "M(IN|AX)A_(S|D)_MMR6")>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "SEL(EQ|NE)Z_(S|D)_MMR6")>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "SEL_(S|D)_MMR6")>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUL], (instrs RINT_S_MMR6, RINT_D_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "M(ADD|SUB)F_(S|D)_MMR6")>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUS], (instrs FMOV_S_MMR6, FMUL_S_MMR6,
 | |
|                                   FSUB_S_MMR6, FMOV_D_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUL], (instrs FDIV_S_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUStore], (instrs SDC1_D64_MMR6)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPULoad], (instrs LDC1_D64_MMR6)>;
 | |
| 
 | |
| // MIPS64
 | |
| // ======
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUMoveGPRFPU], (instrs DMFC1, DMTC1)>;
 | |
| 
 | |
| // MIPS DSP ASE, HasDSP
 | |
| // ====================
 | |
| 
 | |
| def : InstRW<[GenericWriteStore], (instrs SWDSP)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteLoad], (instrs LWDSP)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteMove], (instrs PseudoMTLOHI_DSP)>;
 | |
| 
 | |
| def GenericDSP : ProcResource<1> { let BufferSize = 1; }
 | |
| def GenericDSPShort : SchedWriteRes<[GenericDSP]> { let Latency = 2; }
 | |
| def GenericDSPLong : SchedWriteRes<[GenericDSP]> { let Latency = 6; }
 | |
| def GenericDSPBypass : SchedWriteRes<[GenericDSP]> { let Latency = 1; }
 | |
| def GenericDSPMTHILO : SchedWriteRes<[GenericDSP]> { let Latency = 5; }
 | |
| def GenericDSPLoad : SchedWriteRes<[GenericDSP]> { let Latency = 4; }
 | |
| def GenericDSPMTHLIP : SchedWriteRes<[GenericDSP]> { let Latency = 5; }
 | |
| 
 | |
| def : InstRW<[GenericDSPLong], (instregex "^EXTRV_RS_W$")>;
 | |
| def : InstRW<[GenericDSPLong], (instregex "^EXTRV_R_W$")>;
 | |
| def : InstRW<[GenericDSPLong], (instregex "^EXTRV_S_H$")>;
 | |
| def : InstRW<[GenericDSPLong], (instregex "^EXTRV_W$")>;
 | |
| def : InstRW<[GenericDSPLong], (instregex "^EXTR_RS_W$")>;
 | |
| def : InstRW<[GenericDSPLong], (instregex "^EXTR_R_W$")>;
 | |
| def : InstRW<[GenericDSPLong], (instregex "^EXTR_S_H$")>;
 | |
| def : InstRW<[GenericDSPLong], (instregex "^EXTR_W$")>;
 | |
| def : InstRW<[GenericDSPLong], (instregex "^INSV$")>;
 | |
| 
 | |
| def : InstRW<[GenericDSPMTHLIP], (instregex "^MTHLIP$")>;
 | |
| def : InstRW<[GenericDSPMTHILO], (instregex "^MTHI_DSP$")>;
 | |
| def : InstRW<[GenericDSPMTHILO], (instregex "^MTLO_DSP$")>;
 | |
| 
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ABSQ_S_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ABSQ_S_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDQ_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDQ_S_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDQ_S_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDSC$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDU_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDU_S_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDWC$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^BITREV$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^BPOSGE32$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPGU_EQ_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPGU_LE_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPGU_LT_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPU_EQ_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPU_LE_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPU_LT_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMP_EQ_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMP_LE_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMP_LT_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPAQ_SA_L_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPAQ_S_W_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPAU_H_QBL$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPAU_H_QBR$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPSQ_SA_L_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPSQ_S_W_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPSU_H_QBL$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPSU_H_QBR$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^EXTPDPV$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^EXTPDP$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^EXTPV$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^EXTP$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^LBUX$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^LHX$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^LWX$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MADDU_DSP$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MADD_DSP$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MAQ_SA_W_PHL$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MAQ_SA_W_PHR$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MAQ_S_W_PHL$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MAQ_S_W_PHR$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MFHI_DSP$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MFLO_DSP$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MODSUB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MSUBU_DSP$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MSUB_DSP$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULEQ_S_W_PHL$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULEQ_S_W_PHR$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULEU_S_PH_QBL$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULEU_S_PH_QBR$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULQ_RS_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULSAQ_S_W_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULTU_DSP$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULT_DSP$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PACKRL_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PICK_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PICK_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEQU_PH_QBLA$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEQU_PH_QBL$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEQU_PH_QBRA$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEQU_PH_QBR$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEQ_W_PHL$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEQ_W_PHR$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEU_PH_QBLA$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEU_PH_QBL$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEU_PH_QBRA$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEU_PH_QBR$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECRQU_S_QB_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECRQ_PH_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECRQ_QB_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECRQ_RS_PH_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^RADDU_W_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^RDDSP$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^REPLV_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^REPLV_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^REPL_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^REPL_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHILOV$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHILO$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHLLV_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHLLV_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHLLV_S_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHLLV_S_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHLL_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHLL_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHLL_S_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHLL_S_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRAV_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRAV_R_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRAV_R_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRA_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRA_R_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRA_R_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRLV_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRL_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBQ_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBQ_S_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBQ_S_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBU_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBU_S_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^WRDSP$")>;
 | |
| 
 | |
| def : InstRW<[GenericDSPShort],
 | |
|              (instregex "^Pseudo(CMP|CMPU)_(EQ|LE|LT)_(PH|QB)$")>;
 | |
| def : InstRW<[GenericDSPShort],
 | |
| 						 (instregex "^PseudoPICK_(PH|QB)$")>;
 | |
| 
 | |
| // MIPS DSP R2 - hasDSP, HasDSPR2, InMicroMips
 | |
| // ===========================================
 | |
| 
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ABSQ_S_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDQH_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDQH_R_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDQH_R_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDQH_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDUH_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDUH_R_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDU_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDU_S_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^APPEND$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^BALIGN$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPGDU_EQ_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPGDU_LE_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPGDU_LT_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPA_W_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPAQX_SA_W_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPAQX_S_W_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPAX_W_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPS_W_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPSQX_S_W_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPSQX_SA_W_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPSX_W_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MUL_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MUL_S_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULQ_RS_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULQ_S_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULQ_S_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULSA_W_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECR_QB_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECR_SRA_PH_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECR_SRA_R_PH_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PREPEND$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRA_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRA_R_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRAV_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRAV_R_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRL_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRLV_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBQH_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBQH_R_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBQH_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBQH_R_W$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBU_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBU_S_PH$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBUH_QB$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBUH_R_QB$")>;
 | |
| 
 | |
| // microMIPS DSP R1 - HasDSP, InMicroMips
 | |
| // ======================================
 | |
| 
 | |
| def : InstRW<[GenericWriteLoad], (instrs LWDSP_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericWriteStore], (instrs SWDSP_MM)>;
 | |
| 
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ABSQ_S_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ABSQ_S_W_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDQ_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDQ_S_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDQ_S_W_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDSC_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDU_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDU_S_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDWC_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^BITREV_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^BPOSGE32_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPGU_EQ_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPGU_LE_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPGU_LT_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPU_EQ_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPU_LE_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPU_LT_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMP_EQ_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMP_LE_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMP_LT_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPAQ_SA_L_W_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPAQ_S_W_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPAU_H_QBL_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPAU_H_QBR_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPSQ_SA_L_W_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPSQ_S_W_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPSU_H_QBL_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPSU_H_QBR_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^EXTPDPV_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^EXTPDP_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^EXTPV_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^EXTP_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^EXTRV_RS_W_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^EXTRV_R_W_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^EXTRV_S_H_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^EXTRV_W_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^EXTR_RS_W_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^EXTR_R_W_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^EXTR_S_H_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^EXTR_W_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^INSV_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^LBUX_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^LHX_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^LWX_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MADDU_DSP_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MADD_DSP_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MAQ_SA_W_PHL_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MAQ_SA_W_PHR_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MAQ_S_W_PHL_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MAQ_S_W_PHR_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MFHI_DSP_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MFLO_DSP_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MODSUB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MOVEP_MMR6$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MOVN_I_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MOVZ_I_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MSUBU_DSP_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MSUB_DSP_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MTHI_DSP_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MTHLIP_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MTLO_DSP_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULEQ_S_W_PHL_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULEQ_S_W_PHR_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULEU_S_PH_QBL_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULEU_S_PH_QBR_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULQ_RS_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULSAQ_S_W_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULTU_DSP_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULT_DSP_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PACKRL_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PICK_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PICK_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEQU_PH_QBLA_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEQU_PH_QBL_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEQU_PH_QBRA_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEQU_PH_QBR_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEQ_W_PHL_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEQ_W_PHR_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEU_PH_QBLA_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEU_PH_QBL_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEU_PH_QBRA_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECEU_PH_QBR_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECRQU_S_QB_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECRQ_PH_W_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECRQ_QB_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECRQ_RS_PH_W_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^RADDU_W_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^RDDSP_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^REPLV_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^REPLV_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^REPL_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^REPL_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHILOV_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHILO_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHLLV_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHLLV_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHLLV_S_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHLLV_S_W_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHLL_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHLL_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHLL_S_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHLL_S_W_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRAV_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRAV_R_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRAV_R_W_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRA_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRA_R_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRA_R_W_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRLV_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRL_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBQ_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBQ_S_PH_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBQ_S_W_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBU_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBU_S_QB_MM$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^WRDSP_MM$")>;
 | |
| 
 | |
| 
 | |
| // microMIPS DSP R2 - hasDSP, HasDSPR2, InMicroMips
 | |
| // ================================================
 | |
| 
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ABSQ_S_QB_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDQH_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDQH_R_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDQH_R_W_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDQH_W_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDUH_QB_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDUH_R_QB_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDU_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^ADDU_S_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^APPEND_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^BALIGN_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPGDU_EQ_QB_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPGDU_LE_QB_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^CMPGDU_LT_QB_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPA_W_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPAQX_SA_W_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPAQX_S_W_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPAX_W_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPS_W_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPSQX_S_W_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPSQX_SA_W_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^DPSX_W_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MUL_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MUL_S_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULQ_RS_W_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULQ_S_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULQ_S_W_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^MULSA_W_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECR_QB_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECR_SRA_PH_W_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PRECR_SRA_R_PH_W_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^PREPEND_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRA_QB_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRA_R_QB_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRAV_QB_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRAV_R_QB_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRL_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SHRLV_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBQH_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBQH_R_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBQH_W_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBQH_R_W_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBU_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBU_S_PH_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBUH_QB_MMR2$")>;
 | |
| def : InstRW<[GenericDSPShort], (instregex "^SUBUH_R_QB_MMR2$")>;
 | |
| 
 | |
| // microMIPS DSP R3 - hasDSP, hasDSPR2, hasDSPR3, InMicroMips
 | |
| // ==========================================================
 | |
| 
 | |
| def : InstRW<[GenericDSPShort], (instregex "^BPOSGE32C_MMR3$")>;
 | |
| 
 | |
| // MIPS MSA ASE - hasMSA
 | |
| // =====================
 | |
| 
 | |
| def GenericWriteMSAShortLogic : SchedWriteRes<[GenericIssueFPUS]>;
 | |
| def GenericWriteMSAShortInt : SchedWriteRes<[GenericIssueFPUS]> {
 | |
| let Latency = 2;
 | |
| }
 | |
| def GenericWriteMoveOtherUnitsToFPU : SchedWriteRes<[GenericIssueFPUS]>;
 | |
| def GenericWriteMSAOther3 : SchedWriteRes<[GenericIssueFPUS]> {
 | |
| let Latency = 3;
 | |
| }
 | |
| def GenericWriteMSALongInt : SchedWriteRes<[GenericIssueFPUS]> {
 | |
| let Latency = 5;
 | |
| }
 | |
| def GenericWriteFPUDivI : SchedWriteRes<[GenericFPQ]> {
 | |
|   let Latency = 33;
 | |
|   let ResourceCycles = [ 33 ];
 | |
| }
 | |
| 
 | |
| // FPUS is also used in moves from floating point and MSA registers to general
 | |
| // purpose registers.
 | |
| def GenericWriteMoveFPUSToOtherUnits : SchedWriteRes<[GenericIssueFPUS]> {
 | |
|   let Latency = 0;
 | |
| }
 | |
| 
 | |
| // FPUL is also used in moves from floating point and MSA registers to general
 | |
| // purpose registers.
 | |
| def GenericWriteMoveFPULToOtherUnits : SchedWriteRes<[GenericIssueFPUL]>;
 | |
| 
 | |
| 
 | |
| // adds_a.[bhwd], adds_[asu].[bhwd], addvi?.[bhwd], asub_[us].[bhwd],
 | |
| // aver?_[us].[bhwd]
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^ADD_A_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^ADDS_[ASU]_[BHWD]$")>;
 | |
| 
 | |
| // TODO: ADDVI_[BHW] might be 1 cycle latency rather than 2. Need to confirm it.
 | |
| // add.[bhwd], addvi.[bhwd], asub_[us].[bhwd], ave.[bhwd], aver.[bhwd]
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^ADDVI?_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^ASUB_[US].[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^AVER?_[US].[BHWD]$")>;
 | |
| 
 | |
| // and.v, andi.b, move.v, ldi.[bhwd], xor.v, nor.v, xori.b, nori.b, lsa
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^MOVE_V$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^LDI_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instrs LSA)>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^(AND|OR|[XN]OR)_V$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^(AND|OR|[XN]OR)I_B$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic],
 | |
|              (instregex "^(AND|OR|[XN]OR)_V_[DHW]_PSEUDO$")>;
 | |
| 
 | |
| // vshf.[bhwd], binsl.[bhwd], binsr.[bhwd], insert.[bhwd], sld?.[bhwd],
 | |
| // bset.[bhwd], bclr.[bhwd], bneg.[bhwd], bsel_v, bseli_b
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^VSHF_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^(BINSL|BINSLI)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^(BINSR|BINSRI)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^INSERT_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^(SLD|SLDI)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^(BSET|BSETI)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^(BCLR|BCLRI)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^(BNEG|BNEGI)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^(BSEL_V|BSELI_B)$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^BMN*Z.*$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt],
 | |
|              (instregex "^BSEL_(H|W|D|FW|FD)_PSEUDO$")>;
 | |
| 
 | |
| // pcnt.[bhwd], sat_s.[bhwd], sat_u.[bhwd]
 | |
| def : InstRW<[GenericWriteMSAOther3], (instregex "^PCNT_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAOther3], (instregex "^SAT_(S|U)_[BHWD]$")>;
 | |
| 
 | |
| // bnz.[bhwdv], cfcmsa, ctcmsa
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^(BNZ|BZ)_[BHWDV]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^C(F|T)CMSA$")>;
 | |
| 
 | |
| // shf.[bhw], fill[bhwd], splat?.[bhwd]
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^SHF_[BHW]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^FILL_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^(SPLAT|SPLATI)_[BHWD]$")>;
 | |
| 
 | |
| // fexp2_w, fexp2_d
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FEXP2_(W|D)$")>;
 | |
| 
 | |
| // compare, converts, round to int, floating point truncate.
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^(CLT|CLTI)_(S|U)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^(CLE|CLEI)_(S|U)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^(CEQ|CEQI)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^CMP_UN_(S|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^CMP_UEQ_(S|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^CMP_EQ_(S|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^CMP_LT_(S|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^CMP_ULT_(S|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^CMP_LE_(S|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^CMP_ULE_(S|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^CMP_F_(D|S)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^CMP_SAF_(D|S)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^CMP_SEQ_(D|S)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^CMP_SLE_(D|S)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^CMP_SLT_(D|S)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^CMP_SUEQ_(D|S)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^CMP_SULE_(D|S)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^CMP_SULT_(D|S)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^CMP_SUN_(D|S)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FS(AF|EQ|LT|LE|NE|OR)_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FSUEQ_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FSULE_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FSULT_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FSUNE_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FSUN_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FCAF_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FCEQ_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FCLE_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FCLT_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FCNE_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FCOR_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FCUEQ_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FCULE_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FCULT_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FCUNE_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FCUN_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FABS_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FFINT_(U|S)_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FFQL_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FFQR_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FTINT_(U|S)_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FRINT_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FTQ_(H|W)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FTRUNC_(U|S)_(W|D)$")>;
 | |
| 
 | |
| // fexdo.[hw], fexupl.[wd], fexupr.[wd]
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FEXDO_(H|W)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FEXUPL_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FEXUPR_(W|D)$")>;
 | |
| 
 | |
| // fclass.[wd], fmax.[wd], fmax_a.[wd], fmin.[wd], fmin_a.[wd], flog2.[wd]
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FCLASS_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FMAX_A_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FMAX_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FMIN_A_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FMIN_(W|D)$")>;
 | |
| def : InstRW<[GenericWriteFPUS], (instregex "^FLOG2_(W|D)$")>;
 | |
| 
 | |
| // interleave right/left, interleave even/odd, insert
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^(ILVR|ILVL)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^(ILVEV|ILVOD)_[BHWD]$")>;
 | |
| 
 | |
| // subs_?.[bhwd], subsus_?.[bhwd], subsuu_?.[bhwd], subvi.[bhwd], subv.[bhwd],
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^SUBS_(S|U)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^SUBSUS_(S|U)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^SUBSUU_(S|U)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^SUBVI_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortInt], (instregex "^SUBV_[BHWD]$")>;
 | |
| 
 | |
| // mod_[su].[bhwd], div_[su].[bhwd]
 | |
| def : InstRW<[GenericWriteFPUDivI], (instregex "^MOD_(S|U)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteFPUDivI], (instregex "^DIV_(S|U)_[BHWD]$")>;
 | |
| 
 | |
| // hadd_[su].[bhwd], hsub_[su].[bhwd], max_[sua].[bhwd], min_[sua].[bhwd],
 | |
| // maxi_[su].[bhwd], mini_[su].[bhwd], sra?.[bhwd], srar?.[bhwd], srlr.[bhwd],
 | |
| // sll?.[bhwd], pckev.[bhwd], pckod.[bhwd], nloc.[bhwd], nlzc.[bhwd],
 | |
| // insve.[bhwd]
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^HADD_(S|U)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^HSUB_(S|U)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^(MAX|MIN)_S_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^(MAX|MIN)_U_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^(MAX|MIN)_A_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic],
 | |
|              (instregex "^(MAXI|MINI)_(S|U)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^(SRA|SRAI)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^(SRL|SRLI)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^(SRAR|SRARI)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^(SRLR|SRLRI)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^(SLL|SLLI)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^(PCKEV|PCKOD)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^(NLOC|NLZC)_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^INSVE_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^INSERT_F(D|W)_PSEUDO$")>;
 | |
| def : InstRW<[GenericWriteMSAShortLogic], (instregex "^FILL_F(D|W)_PSEUDO$")>;
 | |
| 
 | |
| // dpadd_?.[bhwd], dpsub_?.[bhwd], dotp_?.[bhwd], msubv.[bhwd], maddv.[bhwd]
 | |
| // mulv.[bhwd].
 | |
| def : InstRW<[GenericWriteMSALongInt], (instregex "^DPADD_(S|U)_[HWD]$")>;
 | |
| def : InstRW<[GenericWriteMSALongInt], (instregex "^DPSUB_(S|U)_[HWD]$")>;
 | |
| def : InstRW<[GenericWriteMSALongInt], (instregex "^DOTP_(S|U)_[HWD]$")>;
 | |
| def : InstRW<[GenericWriteMSALongInt], (instregex "^MSUBV_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSALongInt], (instregex "^MADDV_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteMSALongInt], (instregex "^MULV_[BHWD]$")>;
 | |
| 
 | |
| // madd?.q.[hw], msub?.q.[hw], mul?.q.[hw]
 | |
| def : InstRW<[GenericWriteMSALongInt], (instregex "^MADDR_Q_[HW]$")>;
 | |
| def : InstRW<[GenericWriteMSALongInt], (instregex "^MADD_Q_[HW]$")>;
 | |
| def : InstRW<[GenericWriteMSALongInt], (instregex "^MSUBR_Q_[HW]$")>;
 | |
| def : InstRW<[GenericWriteMSALongInt], (instregex "^MSUB_Q_[HW]$")>;
 | |
| def : InstRW<[GenericWriteMSALongInt], (instregex "^MULR_Q_[HW]$")>;
 | |
| def : InstRW<[GenericWriteMSALongInt], (instregex "^MUL_Q_[HW]$")>;
 | |
| 
 | |
| // fadd.[dw], fmadd.[dw], fmul.[dw], frcp.[dw], frsqrt.[dw], fsqrt.[dw]
 | |
| // fsub.[dw], fdiv.[dw]
 | |
| def : InstRW<[GenericWriteFPUL], (instregex "^FADD_[DW]$")>;
 | |
| def : InstRW<[GenericWriteFPUL], (instregex "^FMADD_[DW]$")>;
 | |
| def : InstRW<[GenericWriteFPUL], (instregex "^FMSUB_[DW]$")>;
 | |
| def : InstRW<[GenericWriteFPUL], (instregex "^FMUL_[DW]$")>;
 | |
| def : InstRW<[GenericWriteFPUL], (instregex "^FRCP_[DW]$")>;
 | |
| def : InstRW<[GenericWriteFPUL], (instregex "^FRSQRT_[DW]$")>;
 | |
| def : InstRW<[GenericWriteFPUL], (instregex "^FSQRT_[DW]$")>;
 | |
| def : InstRW<[GenericWriteFPUL], (instregex "^FSUB_[DW]$")>;
 | |
| def : InstRW<[GenericWriteFPUL], (instregex "^FDIV_[DW]$")>;
 | |
| 
 | |
| // copy.[su]_[bhwd]
 | |
| def : InstRW<[GenericWriteFPUMoveGPRFPU], (instregex "^COPY_U_[BHW]$")>;
 | |
| def : InstRW<[GenericWriteFPUMoveGPRFPU], (instregex "^COPY_S_[BHWD]$")>;
 | |
| 
 | |
| def : InstRW<[GenericWriteFPUStore], (instregex "^ST_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteFPUStore], (instrs ST_F16)>;
 | |
| def : InstRW<[GenericWriteFPULoad], (instregex "^LD_[BHWD]$")>;
 | |
| def : InstRW<[GenericWriteFPULoad], (instrs LD_F16)>;
 | |
| 
 | |
| // Atomic instructions
 | |
| 
 | |
| // FIXME: Define `WriteAtomic` in the MipsSchedule.td and
 | |
| // attach it to the Atomic2OpsPostRA, AtomicCmpSwapPostRA, ...
 | |
| // classes. Then just define resources for the `WriteAtomic` in each
 | |
| // machine models.
 | |
| def GenericAtomic : ProcResource<1> { let BufferSize = 1; }
 | |
| def GenericWriteAtomic : SchedWriteRes<[GenericAtomic]> { let Latency = 2; }
 | |
| 
 | |
| def : InstRW<[GenericWriteAtomic],
 | |
|     (instregex "^ATOMIC_SWAP_I(8|16|32|64)_POSTRA$")>;
 | |
| def : InstRW<[GenericWriteAtomic],
 | |
|     (instregex "^ATOMIC_CMP_SWAP_I(8|16|32|64)_POSTRA$")>;
 | |
| def : InstRW<[GenericWriteAtomic],
 | |
|     (instregex "^ATOMIC_LOAD_(ADD|SUB|AND|OR|XOR|NAND|MIN|MAX|UMIN|UMAX)"
 | |
|                "_I(8|16|32|64)_POSTRA$")>;
 | |
| }
 |