//===-- CSKYInstrFormats.td - CSKY Instruction Formats -----*- 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 // //===----------------------------------------------------------------------===// class AddrMode val> { bits<5> Value = val; } def AddrModeNone : AddrMode<0>; def AddrMode32B : AddrMode<1>; // ld32.b, ld32.bs, st32.b, st32.bs, +4kb def AddrMode32H : AddrMode<2>; // ld32.h, ld32.hs, st32.h, st32.hs, +8kb def AddrMode32WD : AddrMode<3>; // ld32.w, st32.w, ld32.d, st32.d, +16kb def AddrMode16B : AddrMode<4>; // ld16.b, +32b def AddrMode16H : AddrMode<5>; // ld16.h, +64b def AddrMode16W : AddrMode<6>; // ld16.w, +128b or +1kb def AddrMode32SDF : AddrMode<7>; // flds, fldd, +1kb class CSKYInst pattern> : Instruction { let Namespace = "CSKY"; int Size = sz; AddrMode AM = am; field bits<32> SoftFail = 0; let OutOperandList = outs; let InOperandList = ins; let AsmString = asmstr; let Pattern = pattern; let Itinerary = NoItinerary; let TSFlags{4 - 0} = AM.Value; } class CSKYPseudo pattern> : CSKYInst { let isCodeGenOnly = 1; let isPseudo = 1; } class CSKY32Inst opcode, dag outs, dag ins, string asmstr, list pattern> : CSKYInst { field bits<32> Inst; let Inst{31 - 26} = opcode; } class CSKY16Inst pattern> : CSKYInst { field bits<16> Inst; } // CSKY 32-bit instruction // Format< OP[6] | Offset[26] > // Instruction(1): bsr32 class J opcode, dag outs, dag ins, string op, list pattern> : CSKY32Inst { bits<26> offset; let Inst{25 - 0} = offset; let isCall = 1; let Defs = [ R15 ]; } // Format< OP[6] | RZ[5] | SOP[3] | OFFSET[18] > // Instructions(7): grs, lrs32.b, lrs32.h, lrs32.w, srs32.b, srs32.h, srs32.w class I_18_Z_L sop, string asm, dag outs, dag ins, list pattern> : CSKY32Inst { bits<5> rz; bits<18> offset; let Inst{25 - 21} = rz; let Inst{20 - 18} = sop; let Inst{17 - 0} = offset; } // Format< OP[6] | RZ[5] | RX[5] | IMM[16] > // Instructions(1): ori32 class I_16_ZX pattern> : CSKY32Inst { bits<5> rz; bits<5> rx; bits<16> imm16; let Inst{25 - 21} = rz; let Inst{20 - 16} = rx; let Inst{15 - 0} = imm16; } // Format< OP[6] | SOP[5] | RZ[5] | IMM[16] > // Instructions(3): movi32, movih32, (bgeni32) class I_16_MOV sop, string op, ImmLeaf ImmType> : CSKY32Inst { bits<5> rz; bits<16> imm16; let Inst{25 - 21} = sop; let Inst{20 - 16} = rz; let Inst{15 - 0} = imm16; let isReMaterializable = 1; let isAsCheapAsAMove = 1; let isMoveImm = 1; } // Format< OP[6] | SOP[5] | RZ[5] | OFFSET[16] > // Instructions(1): lrw32 class I_16_Z_L sop, string op, dag ins, list pattern> : CSKY32Inst { bits<5> rz; bits<16> imm16; let Inst{25 - 21} = sop; let Inst{20 - 16} = rz; let Inst{15 - 0} = imm16; } // Format< OP[6] | SOP[5] | 00000[5] | OFFSET[16] > // Instructions(5): bt32, bf32, br32, jmpi32, jsri32 class I_16_L sop, dag outs, dag ins, string asm, list pattern> : CSKY32Inst { bits<16> imm16; let Inst{25 - 21} = sop; let Inst{20 - 16} = 0; let Inst{15 - 0} = imm16; } // Format< OP[6] | SOP[5] | RX[5] | 0000000000000000[16] > // Instructions(2): jmp32, jsr32 class I_16_JX sop, string op, list pattern> : CSKY32Inst { bits<5> rx; bits<16> imm16; let Inst{25 - 21} = sop; let Inst{20 - 16} = rx; let Inst{15 - 0} = 0; } // Format< OP[6] | SOP[5] | RX[5] | 00000000000000[14] | IMM[2] > // Instructions(1): jmpix32 class I_16_J_XI sop, string op, Operand operand, list pattern> : CSKY32Inst { bits<5> rx; bits<2> imm2; let Inst{25 - 21} = sop; let Inst{20 - 16} = rx; let Inst{15 - 2} = 0; let Inst{1 - 0} = imm2; } // Format< OP[6] | SOP[5] | PCODE[5] | 0000000000000000[16] > // Instructions(1): rts32 class I_16_RET sop, bits<5> pcode, string op, list pattern> : CSKY32Inst { let Inst{25 - 21} = sop; let Inst{20 - 16} = pcode; let Inst{15 - 0} = 0; let isTerminator = 1; let isReturn = 1; let isBarrier = 1; let Uses = [ R15 ]; } // Format< OP[6] | SOP[5] | RX[5] | IMM16[16] > // Instructions(3): cmpnei32, cmphsi32, cmplti32 class I_16_X sop, string op, Operand operand> : CSKY32Inst { bits<16> imm16; bits<5> rx; let Inst{25 - 21} = sop; let Inst{20 - 16} = rx; let Inst{15 - 0} = imm16; let isCompare = 1; } // Format< OP[6] | SOP[5] | RX[5] | OFFSET[16] > // Instructions(7): bez32, bnez32, bnezad32, bhz32, blsz32, blz32, bhsz32 class I_16_X_L sop, string op, Operand operand> : CSKY32Inst { bits<5> rx; bits<16> imm16; let Inst{25 - 21} = sop; let Inst{20 - 16} = rx; let Inst{15 - 0} = imm16; let isBranch = 1; let isTerminator = 1; } // Format< OP[6] | RZ[5] | RX[5] | SOP[4] | IMM[12] > // Instructions(5): addi32, subi32, andi32, andni32, xori32 class I_12 sop, string op, SDNode node, ImmLeaf ImmType> : CSKY32Inst { bits<5> rz; bits<5> rx; bits<12> imm12; let Inst{25 - 21} = rz; let Inst{20 - 16} = rx; let Inst{15 - 12} = sop; let Inst{11 - 0} = imm12; } class I_LDST opcode, bits<4> sop, dag outs, dag ins, string op, list pattern> : CSKY32Inst { bits<5> rx; bits<5> rz; bits<12> imm12; let Inst{25 - 21} = rz; let Inst{20 - 16} = rx; let Inst{15 - 12} = sop; let Inst{11 - 0} = imm12; } class I_PLDR opcode, bits<4> sop, dag outs, dag ins, string op, list pattern> : CSKY32Inst { bits<5> rx; bits<12> imm12; let Inst{25 - 21} = 0; let Inst{20 - 16} = rx; let Inst{15 - 12} = sop; let Inst{11 - 0} = imm12; } // Format< OP[6] | RZ[5] | RX[5] | SOP[4] | OFFSET[12] > // Instructions(6): ld32.b, ld32.bs, ld32.h, ld32.hs, ld32.w class I_LD sop, string op, Operand operand> : I_LDST; // Format< OP[6] | RZ[5] | RX[5] | SOP[4] | OFFSET[12] > // Instructions(4): st32.b, st32.h, st32.w class I_ST sop, string op, Operand operand> : I_LDST; // Format< OP[6] | SOP[5] | PCODE[5] | 0000[4] | 000 | R28 | LIST2[3] | R15 | // LIST1[4] > // Instructions(2): push32, pop32 class I_12_PP sop, bits<5> pcode, dag outs, dag ins, string op> : CSKY32Inst { bits<12> regs; let Inst{25 - 21} = sop; let Inst{20 - 16} = pcode; let Inst{15 - 12} = 0; let Inst{11 - 0} = regs; let Uses = [R14]; let Defs = [R14]; } // Format< OP[6] | RZ[5] | RX[5] | SOP[6] | PCODE[5] | IMM[5]> // Instructions(4): incf32, inct32, decf32, dect32 class I_5_ZX sop, bits<5> pcode, string op, ImmLeaf ImmType, list pattern> : CSKY32Inst { bits<5> rz; bits<5> rx; bits<5> imm5; let Inst{25 - 21} = rz; let Inst{20 - 16} = rx; let Inst{15 - 10} = sop; let Inst{9 - 5} = pcode; let Inst{4 - 0} = imm5; let Constraints = "$rz = $false"; } // Format< OP[6] | IMM[5] | RX[5] | SOP[6] | PCODE[5] | RZ[5]> // Instructions(13): decgt32, declt32, decne32, lsli32, lslc32, lsri32 // lsrc32, asri32, asrc32, rotli32, xsr32, bclri32, bseti32 class I_5_XZ sop, bits<5> pcode, string op, dag outs, dag ins, list pattern> : CSKY32Inst { bits<5> imm5; bits<5> rx; bits<5> rz; let Inst{25 - 21} = imm5; let Inst{20 - 16} = rx; let Inst{15 - 10} = sop; let Inst{9 - 5} = pcode; let Inst{4 - 0} = rz; } // mtcr32, mfcr32 class I_5_XZ_CR sop, bits<5> pcode, string opStr, dag outs, dag ins, list pattern> : CSKY32Inst { bits<5> sel; bits<5> rx; bits<5> cr; let Inst{25 - 21} = sel; let Inst{20 - 16} = rx; let Inst{15 - 10} = sop; let Inst{9 - 5} = pcode; let Inst{4 - 0} = cr; } // sync class I_5_XZ_SYNC sop, bits<5> pcode, string opStr, bits<1> S, bits<1> I> : CSKY32Inst { let Inst{25 - 21} = 0; let Inst{20 - 16} = 0; let Inst{15 - 10} = sop; let Inst{9 - 5} = pcode; let Inst{4 - 0} = 0; let Inst{25} = S; let Inst{21} = I; } // Priviledged Instructions class I_5_XZ_PRIVI sop, bits<5> pcode, string opStr> : CSKY32Inst { let Inst{25 - 21} = 0; let Inst{20 - 16} = 0; let Inst{15 - 10} = sop; let Inst{9 - 5} = pcode; let Inst{4 - 0} = 0; } class I_CP sop, dag outs, dag ins, string opStr> : CSKY32Inst { bits<5> cpid; bits<12> usdef; let Inst{25 - 21} = cpid; let Inst{20 - 16} = 0; let Inst{15 - 12} = sop; let Inst{11 - 0} = usdef; } class I_CPOP : CSKY32Inst { bits<5> cpid; bits<20> usdef; let Inst{25 - 21} = cpid; let Inst{20 - 16} = usdef{19-15}; let Inst{15} = 1; let Inst{14 - 0} = usdef{14-0}; } class I_CP_Z sop, dag outs, dag ins, string opStr> : CSKY32Inst { bits<5> cpid; bits<12> usdef; bits<5> rz; let Inst{25 - 21} = cpid; let Inst{20 - 16} = rz; let Inst{15 - 12} = sop; let Inst{11 - 0} = usdef; } class I_5_CACHE sop, bits<5> pcode, string opStr> : CSKY32Inst { let Inst{25 - 21} = pcode; let Inst{20 - 16} = 0; let Inst{15 - 10} = sop; let Inst{9 - 5} = 0b00001; let Inst{4 - 0} = 0; } class I_5_X_CACHE sop, bits<5> pcode, string opStr> : CSKY32Inst { bits<5> rx; let Inst{25 - 21} = pcode; let Inst{20 - 16} = rx; let Inst{15 - 10} = sop; let Inst{9 - 5} = 0b00001; let Inst{4 - 0} = 0; } // Format< OP[6] | RY[5] | RX[5] | SOP[6] | PCODE[5] | IMM[5]> // Instructions(2): ldm32, (ldq32), stm32, (stq32) class I_5_YX opcode, bits<6> sop, dag outs, dag ins, string opStr, list pattern> : CSKY32Inst { bits<10> regs; bits<5> rx; let Inst{25 - 21} = regs{9 - 5}; // ry let Inst{20 - 16} = rx; let Inst{15 - 10} = sop; let Inst{9 - 5} = 0b00001; let Inst{4 - 0} = regs{4 - 0}; // imm5 } // Format< OP[6] | LSB[5] | RX[5] | SOP[6] | MSB[5] | RZ[5]> // Instructions(6): zext32, zextb32, zexth32, sext32, sextb32, sexth32 class I_5_XZ_U sop, dag outs, dag ins, string op, list pattern> : CSKY32Inst { bits<5> rx; bits<5> rz; bits<5> msb; bits<5> lsb; let Inst{25 - 21} = lsb; // lsb let Inst{20 - 16} = rx; let Inst{15 - 10} = sop; let Inst{9 - 5} = msb; // msb let Inst{4 - 0} = rz; } class I_5_XZ_INS sop, dag outs, dag ins, string op, list pattern> : CSKY32Inst { bits<5> rx; bits<5> rz; bits<5> msb; bits<5> lsb; let Inst{25 - 21} = rz; let Inst{20 - 16} = rx; let Inst{15 - 10} = sop; let Inst{9 - 5} = msb; let Inst{4 - 0} = lsb; } // Format< OP[6] | LSB[5] | RX[5] | SOP[6] | MSB[5] | RZ[5]> // Instructions(6): zext32, zextb32, zexth32, sext32, sextb32, sexth32 class I_5_XZ_U2 sop, bits<5> lsb, bits<5> msb, dag outs, dag ins, string op, list pattern> : CSKY32Inst { bits<5> rx; bits<5> rz; let Inst{25 - 21} = lsb; // lsb let Inst{20 - 16} = rx; let Inst{15 - 10} = sop; let Inst{9 - 5} = msb; // msb let Inst{4 - 0} = rz; } // Format< OP[6] | RZ[5] | RX[5] | SOP[6] | SIZE[5] | LSB[5]> // Instructions(1): ins32 class I_5_ZX_U sop, string op, Operand operand, list pattern> : CSKY32Inst { bits<10> size_lsb; bits<5> rz; bits<5> rx; let Inst{25 - 21} = rz; let Inst{20 - 16} = rx; let Inst{15 - 10} = sop; let Inst{9 - 5} = size_lsb{9 - 5}; // size let Inst{4 - 0} = size_lsb{4 - 0}; // lsb } // sextb, sexth class I_5_XZ_US sop, bits<5> lsb, bits<5> msb, string op, SDNode opnode, ValueType type> : I_5_XZ_U2; class I_5_XZ_UZ sop, bits<5> lsb, bits<5> msb, string op, int v> : I_5_XZ_U2; // Format< OP[6] | IMM[5] | RX[5] | SOP[6] | PCODE[5] | 00000 > // Instructions(1): btsti32 class I_5_X sop, bits<5> pcode, string op, ImmLeaf ImmType, list pattern> : CSKY32Inst { bits<5> imm5; bits<5> rx; let Inst{25 - 21} = imm5; let Inst{20 - 16} = rx; let Inst{15 - 10} = sop; let Inst{9 - 5} = pcode; let Inst{4 - 0} = 0; let isCompare = 1; } // Format< OP[6] | IMM[5] | 00000[5] | SOP[6] | PCODE[5] | RZ[5]> // Instructions(1): bmaski32 class I_5_Z sop, bits<5> pcode, string op, ImmLeaf ImmType, list pattern> : CSKY32Inst { bits<5> imm5; bits<5> rz; let Inst{25 - 21} = imm5; let Inst{20 - 16} = 0; let Inst{15 - 10} = sop; let Inst{9 - 5} = pcode; let Inst{4 - 0} = rz; } class I_5_IMM5 opcode, bits<6> sop, bits<5> pcode, string op, ImmLeaf ImmType, list pattern> : CSKY32Inst { bits<5> imm5; let Inst{25 - 21} = imm5; let Inst{20 - 16} = 0; let Inst{15 - 10} = sop; let Inst{9 - 5} = pcode; let Inst{4 - 0} = 0; } // Format< OP[6] | RY[5] | RX[5] | SOP[6] | PCODE[5] | RZ[5] > // Instructions(24): addu32, addc32, subu32, subc32, (rsub32), ixh32, ixw32, // ixd32, and32, andn32, or32, xor32, nor32, lsl32, lsr32, asr32, rotl32 // mult32, divu32, divs32, mul.(u/s)32, mula.32.l, mula.u32, mulall.s16.s class R_YXZ opcode, bits<6> sop, bits<5> pcode, dag outs, dag ins, string op, list pattern> : CSKY32Inst { bits<5> ry; bits<5> rx; bits<5> rz; let Inst{25 - 21} = ry; let Inst{20 - 16} = rx; let Inst{15 - 10} = sop; let Inst{9 - 5} = pcode; let Inst{4 - 0} = rz; } // R_YXZ instructions with simple pattern // Output: GPR:rz // Input: GPR:rx, GPR:ry // Asm string: op rz, rx, ry // Instructions: addu32, subu32, ixh32, ixw32, ixd32, and32, andn32, or32, // xor32, nor32, lsl32, lsr32, asr32, mult32, divu32, divs32 class R_YXZ_SP_F1 sop, bits<5> pcode, PatFrag opnode, string op, bit Commutable = 0> : R_YXZ<0x31, sop, pcode, (outs GPR:$rz), (ins GPR:$rx, GPR:$ry), op, [(set GPR:$rz, (opnode GPR:$rx, GPR:$ry))]> { let isCommutable = Commutable; } // Format< OP[6] | RY[5] | RX[5] | SOP[6] | PCODE[5] | RZ[5] > // Instructions:(8) ldr32.b, ldr32.h, ldr32.bs, ldr32.hs, ldr32.w, // str32.b, str32.h, str32.w class R_YXZ_LDST opcode, bits<6> sop, dag outs, dag ins, string op, list pattern> : CSKY32Inst { bits<5> rx; bits<5> ry; bits<5> rz; bits<5> imm; let Inst{25 - 21} = ry; // ry; let Inst{20 - 16} = rx; // rx; let Inst{15 - 10} = sop; let Inst{9 - 5} = imm; // pcode; let Inst{4 - 0} = rz; } class I_LDR sop, string op> : R_YXZ_LDST<0x34, sop, (outs GPR:$rz), (ins GPR:$rx, GPR:$ry, uimm_shift:$imm), op, []>; class I_STR sop, string op> : R_YXZ_LDST<0x35, sop, (outs), (ins GPR:$rz, GPR:$rx, GPR:$ry, uimm_shift:$imm), op, []>; // Format< OP[6] | RX[5] | RX[5] | SOP[6] | PCODE[5] | RZ[5] > // Instructions:(1) not32 class R_XXZ sop, bits<5> pcode, dag outs, dag ins, string op, list pattern> : CSKY32Inst { bits<5> rx; bits<5> rz; let Inst{25 - 21} = rx; let Inst{20 - 16} = rx; let Inst{15 - 10} = sop; let Inst{9 - 5} = pcode; let Inst{4 - 0} = rz; } // Format< OP[6] | RY[5] | RX[5] | SOP[6] | PCODE[5] | 00000[5] > // Instructions:(4) cmpne32, cmphs32, cmplt32, tst32 class R_YX sop, bits<5> pcode, string op> : CSKY32Inst { bits<5> ry; bits<5> rx; let Inst{25 - 21} = ry; let Inst{20 - 16} = rx; let Inst{15 - 10} = sop; let Inst{9 - 5} = pcode; let Inst{4 - 0} = 0; let isCompare = 1; } // Format< OP[6] | 00000[5] | RX[5] | SOP[6] | PCODE[5] | RZ[5] > // Instructions:(12) // mov32, xtrb0.32, xtrb1.32, xtrb2.32, xtrb3.32, brev32, revb32 // revh32, abs32, ff0.32, ff1.32, bgenr32 class R_XZ sop, bits<5> pcode, string op> : CSKY32Inst { bits<5> rx; bits<5> rz; let Inst{25 - 21} = 0; let Inst{20 - 16} = rx; let Inst{15 - 10} = sop; let Inst{9 - 5} = pcode; let Inst{4 - 0} = rz; } // Format< OP[6] | RZ[5] | RX[5] | SOP[6] | PCODE[5] | 00000[5] > // Instructions:(2) movf32, movt32 class R_ZX sop, bits<5> pcode, string op, list pattern> : CSKY32Inst { bits<5> rz; bits<5> rx; let Inst{25 - 21} = rz; let Inst{20 - 16} = rx; let Inst{15 - 10} = sop; let Inst{9 - 5} = pcode; let Inst{4 - 0} = 0; let Constraints = "$rz = $false"; let isSelect = 1; } // Format< OP[6] | 00000[5] | RX[5] | SOP[6] | PCODE[5] | 00000[5] > // Instructions:(1) tstnbz32 class R_X sop, bits<5> pcode, dag outs, dag ins, string op, list pattern> : CSKY32Inst { bits<5> rx; let Inst{25 - 21} = 0; let Inst{20 - 16} = rx; let Inst{15 - 10} = sop; let Inst{9 - 5} = pcode; let Inst{4 - 0} = 0; } // Format< OP[6] | 00000[5] | 00000[5] | SOP[6] | PCODE[5] | RZ[5] > // Instructions:(2) mvc32, mvcv32 class R_Z_1 sop, bits<5> pcode, string op> : CSKY32Inst { bits<5> rz; let Inst{25 - 21} = 0; let Inst{20 - 16} = 0; let Inst{15 - 10} = sop; let Inst{9 - 5} = pcode; let Inst{4 - 0} = rz; } // Format< OP[6] | RZ[5] | 00000[5] | SOP[6] | PCODE[5] | 00000[5] > // Instructions:(2) clrf32, clrt32 class R_Z_2 sop, bits<5> pcode, string op, list pattern> : CSKY32Inst { bits<5> rz; let Inst{25 - 21} = rz; let Inst{20 - 16} = 0; let Inst{15 - 10} = sop; let Inst{9 - 5} = pcode; let Inst{4 - 0} = 0; let Constraints = "$rz = $false"; } class BAR sop, string op, bits<1> signed> : CSKY32Inst { let Inst{25} = signed; let Inst{24 - 16} = 0; let Inst{15 - 5} = 0x421; let Inst{4 - 0} = sop; let hasSideEffects = 1; let mayLoad = 0; let mayStore = 0; }