2015-10-13 00:07:25 +08:00
|
|
|
//===-- MicroMipsDSPInstrFormats.td - Instruction Formats --*- tablegen -*-===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// 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
|
2015-10-13 00:07:25 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
class MMDSPInst<string opstr = "">
|
2018-05-30 20:40:53 +08:00
|
|
|
: MipsInst<(outs), (ins), "", [], NoItinerary, FrmOther> {
|
2018-03-12 21:16:12 +08:00
|
|
|
let ASEPredicate = [HasDSP];
|
2018-06-20 21:29:57 +08:00
|
|
|
let EncodingPredicates = [InMicroMips];
|
2015-10-13 00:07:25 +08:00
|
|
|
string BaseOpcode = opstr;
|
|
|
|
string Arch = "mmdsp";
|
|
|
|
let DecoderNamespace = "MicroMips";
|
|
|
|
}
|
|
|
|
|
2015-12-18 16:59:37 +08:00
|
|
|
class MMDSPInstAlias<string Asm, dag Result, bit Emit = 0b1>
|
|
|
|
: InstAlias<Asm, Result, Emit>, PredicateControl {
|
2018-03-12 21:16:12 +08:00
|
|
|
let ASEPredicate = [HasDSP];
|
2015-12-18 16:59:37 +08:00
|
|
|
let AdditionalPredicates = [InMicroMips];
|
|
|
|
}
|
|
|
|
|
2015-10-15 16:59:45 +08:00
|
|
|
class POOL32A_3R_FMT<string opstr, bits<11> op> : MMDSPInst<opstr> {
|
2015-10-13 00:07:25 +08:00
|
|
|
bits<5> rd;
|
|
|
|
bits<5> rs;
|
|
|
|
bits<5> rt;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0b000000;
|
|
|
|
let Inst{25-21} = rt;
|
|
|
|
let Inst{20-16} = rs;
|
|
|
|
let Inst{15-11} = rd;
|
|
|
|
let Inst{10-0} = op;
|
|
|
|
}
|
2015-10-15 16:59:45 +08:00
|
|
|
|
2015-10-19 14:34:44 +08:00
|
|
|
class POOL32A_2R_FMT<string opstr, bits<10> op> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rt;
|
|
|
|
bits<5> rs;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0b000000;
|
|
|
|
let Inst{25-21} = rt;
|
|
|
|
let Inst{20-16} = rs;
|
|
|
|
let Inst{15-6} = op;
|
|
|
|
let Inst{5-0} = 0b111100;
|
|
|
|
}
|
|
|
|
|
|
|
|
class POOL32A_2RAC_FMT<string opstr, bits<8> op> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rt;
|
|
|
|
bits<5> rs;
|
|
|
|
bits<2> ac;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0b000000;
|
|
|
|
let Inst{25-21} = rt;
|
|
|
|
let Inst{20-16} = rs;
|
|
|
|
let Inst{15-14} = ac;
|
|
|
|
let Inst{13-6} = op;
|
|
|
|
let Inst{5-0} = 0b111100;
|
|
|
|
}
|
2015-10-19 15:16:26 +08:00
|
|
|
|
|
|
|
class POOL32A_3RB0_FMT<string opstr, bits<10> op> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rd;
|
|
|
|
bits<5> rs;
|
|
|
|
bits<5> rt;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0b000000;
|
|
|
|
let Inst{25-21} = rt;
|
|
|
|
let Inst{20-16} = rs;
|
|
|
|
let Inst{15-11} = rd;
|
|
|
|
let Inst{10} = 0b0;
|
|
|
|
let Inst{9-0} = op;
|
|
|
|
}
|
2015-10-23 14:39:29 +08:00
|
|
|
|
|
|
|
class POOL32A_2RSA4_FMT<string opstr, bits<12> op> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rt;
|
|
|
|
bits<5> rs;
|
|
|
|
bits<4> sa;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0b000000;
|
|
|
|
let Inst{25-21} = rt;
|
|
|
|
let Inst{20-16} = rs;
|
|
|
|
let Inst{15-12} = sa;
|
|
|
|
let Inst{11-0} = op;
|
|
|
|
}
|
|
|
|
|
|
|
|
class POOL32A_2RSA3_FMT<string opstr, bits<7> op> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rt;
|
|
|
|
bits<5> rs;
|
|
|
|
bits<3> sa;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0b000000;
|
|
|
|
let Inst{25-21} = rt;
|
|
|
|
let Inst{20-16} = rs;
|
|
|
|
let Inst{15-13} = sa;
|
|
|
|
let Inst{12-6} = op;
|
|
|
|
let Inst{5-0} = 0b111100;
|
|
|
|
}
|
|
|
|
|
|
|
|
class POOL32A_2RSA5B0_FMT<string opstr, bits<10> op> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rt;
|
|
|
|
bits<5> rs;
|
|
|
|
bits<5> sa;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0b000000;
|
|
|
|
let Inst{25-21} = rt;
|
|
|
|
let Inst{20-16} = rs;
|
|
|
|
let Inst{15-11} = sa;
|
|
|
|
let Inst{10} = 0b0;
|
|
|
|
let Inst{9-0} = op;
|
|
|
|
}
|
2015-11-13 21:14:25 +08:00
|
|
|
|
|
|
|
class POOL32A_2RSA4B0_FMT<string opstr, bits<11> op> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rt;
|
|
|
|
bits<5> rs;
|
|
|
|
bits<4> sa;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0b000000;
|
|
|
|
let Inst{25-21} = rt;
|
|
|
|
let Inst{20-16} = rs;
|
|
|
|
let Inst{15-12} = sa;
|
|
|
|
let Inst{11} = 0b0;
|
|
|
|
let Inst{10-0} = op;
|
|
|
|
}
|
|
|
|
|
|
|
|
class POOL32A_2RSA4OP6_FMT<string opstr, bits<6> op> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rt;
|
|
|
|
bits<5> rs;
|
|
|
|
bits<4> sa;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0b000000;
|
|
|
|
let Inst{25-21} = rt;
|
|
|
|
let Inst{20-16} = rs;
|
|
|
|
let Inst{15-12} = sa;
|
|
|
|
let Inst{11-6} = op;
|
|
|
|
let Inst{5-0} = 0b111100;
|
|
|
|
}
|
2015-11-17 20:54:15 +08:00
|
|
|
|
|
|
|
class POOL32A_1RIMM5AC_FMT<string opstr, bits<8> funct> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rt;
|
|
|
|
bits<5> imm;
|
|
|
|
bits<2> ac;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0b000000;
|
|
|
|
let Inst{25-21} = rt;
|
|
|
|
let Inst{20-16} = imm;
|
|
|
|
let Inst{15-14} = ac;
|
|
|
|
let Inst{13-6} = funct;
|
|
|
|
let Inst{5-0} = 0b111100;
|
|
|
|
}
|
2015-11-30 16:37:38 +08:00
|
|
|
|
|
|
|
class POOL32A_2RSA5_FMT<string opstr, bits<11> op> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rt;
|
|
|
|
bits<5> rs;
|
|
|
|
bits<5> sa;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0b000000;
|
|
|
|
let Inst{25-21} = rt;
|
|
|
|
let Inst{20-16} = rs;
|
|
|
|
let Inst{15-11} = sa;
|
|
|
|
let Inst{10-0} = op;
|
|
|
|
}
|
2015-11-30 20:58:39 +08:00
|
|
|
|
|
|
|
class POOL32A_1RMEMB0_FMT<string opstr, bits<10> funct> : MMDSPInst<opstr> {
|
|
|
|
bits<5> index;
|
|
|
|
bits<5> base;
|
|
|
|
bits<5> rd;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0;
|
|
|
|
let Inst{25-21} = index;
|
|
|
|
let Inst{20-16} = base;
|
|
|
|
let Inst{15-11} = rd;
|
|
|
|
let Inst{10} = 0b0;
|
|
|
|
let Inst{9-0} = funct;
|
|
|
|
}
|
|
|
|
|
|
|
|
class POOL32A_1RAC_FMT<string instr_asm, bits<8> funct> : MMDSPInst<instr_asm> {
|
|
|
|
bits<5> rs;
|
|
|
|
bits<2> ac;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0;
|
|
|
|
let Inst{25-21} = 0;
|
|
|
|
let Inst{20-16} = rs;
|
|
|
|
let Inst{15-14} = ac;
|
|
|
|
let Inst{13-6} = funct;
|
|
|
|
let Inst{5-0} = 0b111100;
|
|
|
|
}
|
2015-12-02 17:31:24 +08:00
|
|
|
|
|
|
|
class POOL32A_1RMASK7_FMT<string opstr, bits<8> op> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rt;
|
|
|
|
bits<7> mask;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0b000000;
|
|
|
|
let Inst{25-21} = rt;
|
|
|
|
let Inst{20-14} = mask;
|
|
|
|
let Inst{13-6} = op;
|
|
|
|
let Inst{5-0} = 0b111100;
|
|
|
|
}
|
|
|
|
|
|
|
|
class POOL32A_1RIMM10_FMT<string opstr, bits<10> op> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rd;
|
|
|
|
bits<10> imm;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0;
|
|
|
|
let Inst{25-16} = imm;
|
|
|
|
let Inst{15-11} = rd;
|
|
|
|
let Inst{10} = 0;
|
|
|
|
let Inst{9-0} = op;
|
|
|
|
}
|
|
|
|
|
|
|
|
class POOL32A_1RIMM8_FMT<string opstr, bits<6> op> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rt;
|
|
|
|
bits<8> imm;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0;
|
|
|
|
let Inst{25-21} = rt;
|
|
|
|
let Inst{20-13} = imm;
|
|
|
|
let Inst{12} = 0;
|
|
|
|
let Inst{11-6} = op;
|
|
|
|
let Inst{5-0} = 0b111100;
|
|
|
|
}
|
2015-12-18 16:59:37 +08:00
|
|
|
|
|
|
|
class POOL32A_4B0SHIFT6AC4B0_FMT<string opstr, bits<10> op> : MMDSPInst<opstr> {
|
|
|
|
bits<6> shift;
|
|
|
|
bits<2> ac;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0b000000;
|
|
|
|
let Inst{25-22} = 0b0000;
|
|
|
|
let Inst{21-16} = shift;
|
|
|
|
let Inst{15-14} = ac;
|
|
|
|
let Inst{13-10} = 0b0000;
|
|
|
|
let Inst{9-0} = op;
|
|
|
|
}
|
|
|
|
|
|
|
|
class POOL32A_5B01RAC_FMT<string opstr, bits<8> op> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rs;
|
|
|
|
bits<2> ac;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0b000000;
|
|
|
|
let Inst{25-21} = 0b00000;
|
|
|
|
let Inst{20-16} = rs;
|
|
|
|
let Inst{15-14} = ac;
|
|
|
|
let Inst{13-6} = op;
|
|
|
|
let Inst{5-0} = 0b111100;
|
|
|
|
}
|
2016-05-13 19:32:53 +08:00
|
|
|
|
|
|
|
class POOL32I_IMMB0_FMT<string opstr, bits<5> op> : MMDSPInst<opstr> {
|
|
|
|
bits<16> offset;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0b010000;
|
|
|
|
let Inst{25-21} = op;
|
|
|
|
let Inst{20-16} = 0;
|
2016-05-17 17:32:58 +08:00
|
|
|
let Inst{15-0} = offset;
|
|
|
|
}
|
|
|
|
|
|
|
|
class POOL32A_2RBP_FMT<string opstr> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rt;
|
|
|
|
bits<5> rs;
|
|
|
|
bits<2> bp;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0;
|
|
|
|
let Inst{25-21} = rt;
|
|
|
|
let Inst{20-16} = rs;
|
|
|
|
let Inst{15-14} = bp;
|
|
|
|
let Inst{13-6} = 0b00100010;
|
|
|
|
let Inst{5-0} = 0b111100;
|
|
|
|
}
|
|
|
|
|
|
|
|
class POOL32A_2RB0_FMT<string opstr, bits<10> op> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rt;
|
|
|
|
bits<5> rs;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0;
|
|
|
|
let Inst{25-21} = rt;
|
|
|
|
let Inst{20-16} = rs;
|
|
|
|
let Inst{15-10} = 0;
|
|
|
|
let Inst{9-0} = op;
|
|
|
|
}
|
|
|
|
|
|
|
|
class POOL32S_3RB0_FMT<string opstr, bits<10> op> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rt;
|
|
|
|
bits<5> rs;
|
|
|
|
bits<5> rd;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0b010110;
|
|
|
|
let Inst{25-21} = rt;
|
|
|
|
let Inst{20-16} = rs;
|
|
|
|
let Inst{15-11} = rd;
|
|
|
|
let Inst{10} = 0b0;
|
|
|
|
let Inst{9-0} = op;
|
|
|
|
}
|
|
|
|
|
|
|
|
class POOL32A_2R2B0_FMT<string opstr, bits<10> op> : MMDSPInst<opstr> {
|
|
|
|
bits<5> rt;
|
|
|
|
bits<5> rs;
|
|
|
|
|
|
|
|
let Inst{31-26} = 0;
|
|
|
|
let Inst{25-21} = rt;
|
|
|
|
let Inst{20-16} = rs;
|
|
|
|
let Inst{15-11} = 0;
|
|
|
|
let Inst{10} = 0;
|
|
|
|
let Inst{9-0} = op;
|
2016-05-13 19:32:53 +08:00
|
|
|
}
|