1//=- MicroMips32r6InstrFormats.td - Mips32r6 Instruction Formats -*- tablegen -*-==//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file describes microMIPS32r6 instruction formats.
10//
11//===----------------------------------------------------------------------===//
12
13class MMR6Arch<string opstr> {
14  string Arch = "micromipsr6";
15  string BaseOpcode = opstr;
16  string DecoderNamespace = "MicroMipsR6";
17}
18
19//===----------------------------------------------------------------------===//
20//
21// Disambiguators
22//
23//===----------------------------------------------------------------------===//
24//
25// Some encodings are ambiguous except by comparing field values.
26
27class MMDecodeDisambiguatedBy<string Name> : DecodeDisambiguates<Name> {
28  string DecoderNamespace = "MicroMipsR6_Ambiguous";
29}
30
31//===----------------------------------------------------------------------===//
32//
33// Encoding Formats
34//
35//===----------------------------------------------------------------------===//
36
37class BC16_FM_MM16R6 {
38  bits<10> offset;
39
40  bits<16> Inst;
41
42  let Inst{15-10} = 0x33;
43  let Inst{9-0}   = offset;
44}
45
46class BEQZC_BNEZC_FM_MM16R6<bits<6> op> {
47  bits<3> rs;
48  bits<7> offset;
49
50  bits<16> Inst;
51
52  let Inst{15-10} = op;
53  let Inst{9-7}   = rs;
54  let Inst{6-0}   = offset;
55}
56
57class POOL16C_JALRC_FM_MM16R6<bits<5> op> {
58  bits<5> rs;
59
60  bits<16> Inst;
61
62  let Inst{15-10} = 0x11;
63  let Inst{9-5}   = rs;
64  let Inst{4-0}   = op;
65}
66
67class POP35_BOVC_FM_MMR6<string instr_asm> : MipsR6Inst, MMR6Arch<instr_asm> {
68  bits<5> rt;
69  bits<5> rs;
70  bits<16> offset;
71
72  bits<32> Inst;
73
74  let Inst{31-26} = 0b011101;
75  let Inst{25-21} = rt;
76  let Inst{20-16} = rs;
77  let Inst{15-0} = offset;
78}
79
80class POP37_BNVC_FM_MMR6<string instr_asm> : MipsR6Inst, MMR6Arch<instr_asm> {
81  bits<5> rt;
82  bits<5> rs;
83  bits<16> offset;
84
85  bits<32> Inst;
86
87  let Inst{31-26} = 0b011111;
88  let Inst{25-21} = rt;
89  let Inst{20-16} = rs;
90  let Inst{15-0} = offset;
91}
92
93class POOL16C_JRCADDIUSP_FM_MM16R6<bits<5> op> {
94  bits<5> imm;
95
96  bits<16> Inst;
97
98  let Inst{15-10} = 0x11;
99  let Inst{9-5}   = imm;
100  let Inst{4-0}   = op;
101}
102
103class POOL16C_LWM_SWM_FM_MM16R6<bits<4> funct> {
104  bits<2> rt;
105  bits<4> addr;
106
107  bits<16> Inst;
108
109  let Inst{15-10} = 0x11;
110  let Inst{9-8}   = rt;
111  let Inst{7-4}   = addr;
112  let Inst{3-0}   = funct;
113}
114
115class POOL32A_BITSWAP_FM_MMR6<bits<6> funct> : MipsR6Inst {
116  bits<5> rd;
117  bits<5> rt;
118
119  bits<32> Inst;
120
121  let Inst{31-26} = 0b000000;
122  let Inst{25-21} = rt;
123  let Inst{20-16} = rd;
124  let Inst{15-12} = 0b0000;
125  let Inst{11-6} = funct;
126  let Inst{5-0} = 0b111100;
127}
128
129class CACHE_PREF_FM_MMR6<bits<6> opgroup, bits<4> funct> : MipsR6Inst {
130  bits<21> addr;
131  bits<5> hint;
132
133  bits<32> Inst;
134
135  let Inst{31-26} = opgroup;
136  let Inst{25-21} = hint;
137  let Inst{20-16} = addr{20-16};
138  let Inst{15-12} = funct;
139  let Inst{11-0}  = addr{11-0};
140}
141
142class ARITH_FM_MMR6<string instr_asm, bits<10> funct> : MMR6Arch<instr_asm> {
143  bits<5> rd;
144  bits<5> rt;
145  bits<5> rs;
146
147  bits<32> Inst;
148
149  let Inst{31-26} = 0;
150  let Inst{25-21} = rt;
151  let Inst{20-16} = rs;
152  let Inst{15-11} = rd;
153  let Inst{10}    = 0;
154  let Inst{9-0}   = funct;
155}
156
157class ADDI_FM_MMR6<string instr_asm, bits<6> op> : MMR6Arch<instr_asm> {
158  bits<5>  rt;
159  bits<5>  rs;
160  bits<16> imm16;
161
162  bits<32> Inst;
163
164  let Inst{31-26} = op;
165  let Inst{25-21} = rt;
166  let Inst{20-16} = rs;
167  let Inst{15-0}  = imm16;
168}
169
170class LB32_FM_MMR6 : MipsR6Inst {
171  bits<21> addr;
172  bits<5> rt;
173  bits<5> base = addr{20-16};
174  bits<16> offset = addr{15-0};
175
176  bits<32> Inst;
177
178  let Inst{31-26} = 0b000111;
179  let Inst{25-21} = rt;
180  let Inst{20-16} = base;
181  let Inst{15-0}  = offset;
182}
183
184class LBU32_FM_MMR6 : MipsR6Inst {
185  bits<21> addr;
186  bits<5> rt;
187  bits<5> base = addr{20-16};
188  bits<16> offset = addr{15-0};
189
190  bits<32> Inst;
191
192  let Inst{31-26} = 0b000101;
193  let Inst{25-21} = rt;
194  let Inst{20-16} = base;
195  let Inst{15-0}  = offset;
196}
197
198class PCREL19_FM_MMR6<bits<2> funct> : MipsR6Inst {
199  bits<5> rt;
200  bits<19> imm;
201
202  bits<32> Inst;
203
204  let Inst{31-26} = 0b011110;
205  let Inst{25-21} = rt;
206  let Inst{20-19} = funct;
207  let Inst{18-0}  = imm;
208}
209
210class PCREL16_FM_MMR6<bits<5> funct> : MipsR6Inst {
211  bits<5> rt;
212  bits<16> imm;
213
214  bits<32> Inst;
215
216  let Inst{31-26} = 0b011110;
217  let Inst{25-21} = rt;
218  let Inst{20-16} = funct;
219  let Inst{15-0}  = imm;
220}
221
222class POOL32A_FM_MMR6<bits<10> funct> : MipsR6Inst {
223  bits<5> rd;
224  bits<5> rs;
225  bits<5> rt;
226
227  bits<32> Inst;
228
229  let Inst{31-26} = 0b000000;
230  let Inst{25-21} = rt;
231  let Inst{20-16} = rs;
232  let Inst{15-11} = rd;
233  let Inst{10}    = 0;
234  let Inst{9-0}   = funct;
235}
236
237class POOL32A_PAUSE_FM_MMR6<string instr_asm, bits<5> op>
238    : MMR6Arch<instr_asm> {
239  bits<32> Inst;
240
241  let Inst{31-26} = 0;
242  let Inst{25-21} = 0;
243  let Inst{20-16} = 0;
244  let Inst{15-11} = op;
245  let Inst{10-6} = 0;
246  let Inst{5-0} = 0;
247}
248
249class POOL32A_RDPGPR_FM_MMR6<bits<10> funct> {
250  bits<5> rt;
251  bits<5> rd;
252  bits<32> Inst;
253
254  let Inst{31-26} = 0;
255  let Inst{25-21} = rt;
256  let Inst{20-16} = rd;
257  let Inst{15-6} = funct;
258  let Inst{5-0} = 0b111100;
259}
260
261class POOL32A_RDHWR_FM_MMR6 {
262  bits<5> rt;
263  bits<5> rs;
264  bits<3> sel;
265  bits<32> Inst;
266
267  let Inst{31-26} = 0;
268  let Inst{25-21} = rt;
269  let Inst{20-16} = rs;
270  let Inst{15-14} = 0;
271  let Inst{13-11} = sel;
272  let Inst{10} = 0;
273  let Inst{9-0} = 0b0111000000;
274}
275
276class POOL32A_SYNC_FM_MMR6 {
277  bits<5> stype;
278
279  bits<32> Inst;
280
281  let Inst{31-26} = 0;
282  let Inst{25-21} = 0;
283  let Inst{20-16} = stype;
284  let Inst{15-6}  = 0b0110101101;
285  let Inst{5-0}   = 0b111100;
286}
287
288class POOL32I_SYNCI_FM_MMR6 {
289  bits<21> addr;
290  bits<5> base = addr{20-16};
291  bits<16> immediate = addr{15-0};
292
293  bits<32> Inst;
294
295  let Inst{31-26} = 0b010000;
296  let Inst{25-21} = 0b01100;
297  let Inst{20-16} = base;
298  let Inst{15-0}  = immediate;
299}
300
301class POOL32A_2R_FM_MMR6<bits<10> funct> : MipsR6Inst {
302  bits<5> rs;
303  bits<5> rt;
304
305  bits<32> Inst;
306
307  let Inst{31-26} = 0b000000;
308  let Inst{25-21} = rt;
309  let Inst{20-16} = rs;
310  let Inst{15-6}  = funct;
311  let Inst{5-0}   = 0b111100;
312}
313
314class SPECIAL_2R_FM_MMR6<bits<6> funct> : MipsR6Inst {
315  bits<5> rs;
316  bits<5> rt;
317
318  bits<32> Inst;
319
320  let Inst{31-26} = 0b000000;
321  let Inst{25-21} = rs;
322  let Inst{20-16} = 0b00000;
323  let Inst{15-11} = rt;
324  let Inst{10-6}  = 0b00001;
325  let Inst{5-0}   = funct;
326}
327
328class POOL32A_ALIGN_FM_MMR6<bits<6> funct> : MipsR6Inst {
329  bits<5> rd;
330  bits<5> rs;
331  bits<5> rt;
332  bits<2> bp;
333
334  bits<32> Inst;
335
336  let Inst{31-26} = 0b000000;
337  let Inst{25-21} = rs;
338  let Inst{20-16} = rt;
339  let Inst{15-11} = rd;
340  let Inst{10-9}  = bp;
341  let Inst{8-6}   = 0b000;
342  let Inst{5-0}   = funct;
343}
344
345class AUI_FM_MMR6 : MipsR6Inst {
346  bits<5> rs;
347  bits<5> rt;
348  bits<16> imm;
349
350  bits<32> Inst;
351
352  let Inst{31-26} = 0b000100;
353  let Inst{25-21} = rt;
354  let Inst{20-16} = rs;
355  let Inst{15-0} = imm;
356}
357
358class POOL32A_LSA_FM<bits<6> funct> : MipsR6Inst {
359  bits<5> rd;
360  bits<5> rs;
361  bits<5> rt;
362  bits<2> imm2;
363
364  bits<32> Inst;
365
366  let Inst{31-26} = 0b000000;
367  let Inst{25-21} = rt;
368  let Inst{20-16} = rs;
369  let Inst{15-11} = rd;
370  let Inst{10-9}  = imm2;
371  let Inst{8-6}   = 0b000;
372  let Inst{5-0}   = funct;
373}
374
375class SB32_SH32_STORE_FM_MMR6<bits<6> op> {
376  bits<5> rt;
377  bits<21> addr;
378  bits<5> base = addr{20-16};
379  bits<16> offset = addr{15-0};
380
381  bits<32> Inst;
382
383  let Inst{31-26} = op;
384  let Inst{25-21} = rt;
385  let Inst{20-16} = base;
386  let Inst{15-0}  = offset;
387}
388
389class LOAD_WORD_FM_MMR6 {
390  bits<5> rt;
391  bits<21> addr;
392  bits<5> base = addr{20-16};
393  bits<16> offset = addr{15-0};
394
395  bits<32> Inst;
396
397  let Inst{31-26} = 0b111111;
398  let Inst{25-21} = rt;
399  let Inst{20-16} = base;
400  let Inst{15-0}  = offset;
401}
402
403class LOAD_UPPER_IMM_FM_MMR6 {
404  bits<5> rt;
405  bits<16> imm16;
406
407  bits<32> Inst;
408
409  let Inst{31-26} = 0b000100;
410  let Inst{25-21} = rt;
411  let Inst{20-16} = 0;
412  let Inst{15-0}  = imm16;
413}
414
415class CMP_BRANCH_1R_RT_OFF16_FM_MMR6<string instr_asm, bits<6> funct>
416    : MMR6Arch<instr_asm>, MipsR6Inst {
417  bits<5> rt;
418  bits<16> offset;
419
420  bits<32> Inst;
421
422  let Inst{31-26} = funct;
423  let Inst{25-21} = rt;
424  let Inst{20-16} = 0b00000;
425  let Inst{15-0}  = offset;
426}
427
428class CMP_BRANCH_1R_BOTH_OFF16_FM_MMR6<string instr_asm, bits<6> funct>
429    : MMR6Arch<instr_asm>, MipsR6Inst {
430  bits<5> rt;
431  bits<16> offset;
432
433  bits<32> Inst;
434
435  let Inst{31-26} = funct;
436  let Inst{25-21} = rt;
437  let Inst{20-16} = rt;
438  let Inst{15-0}  = offset;
439}
440
441class POOL32A_JALRC_FM_MMR6<string instr_asm, bits<10> funct>
442    : MipsR6Inst, MMR6Arch<instr_asm> {
443  bits<5> rt;
444  bits<5> rs;
445
446  bits<32> Inst;
447
448  let Inst{31-26} = 0;
449  let Inst{25-21} = rt;
450  let Inst{20-16} = rs;
451  let Inst{15-6} = funct;
452  let Inst{5-0} = 0b111100;
453}
454
455class POOL32A_EXT_INS_FM_MMR6<string instr_asm, bits<6> funct>
456    : MMR6Arch<instr_asm>, MipsR6Inst {
457  bits<5> rt;
458  bits<5> rs;
459  bits<5> size;
460  bits<5> pos;
461
462  bits<32> Inst;
463
464  let Inst{31-26} = 0;
465  let Inst{25-21} = rt;
466  let Inst{20-16} = rs;
467  let Inst{15-11} = size;
468  let Inst{10-6}  = pos;
469  let Inst{5-0}   = funct;
470}
471
472class POOL32A_ERET_FM_MMR6<string instr_asm, bits<10> funct>
473    : MMR6Arch<instr_asm> {
474  bits<32> Inst;
475
476  let Inst{31-26} = 0x00;
477  let Inst{25-16} = 0x00;
478  let Inst{15-6}  = funct;
479  let Inst{5-0}   = 0x3c;
480}
481
482class ERETNC_FM_MMR6<string instr_asm> : MMR6Arch<instr_asm> {
483  bits<32> Inst;
484
485  let Inst{31-26} = 0x00;
486  let Inst{25-17} = 0x00;
487  let Inst{16-16} = 0x01;
488  let Inst{15-6}  = 0x3cd;
489  let Inst{5-0}   = 0x3c;
490}
491
492class BREAK_MMR6_ENC<string instr_asm> : MMR6Arch<instr_asm> {
493  bits<10> code_1;
494  bits<10> code_2;
495  bits<32> Inst;
496  let Inst{31-26} = 0x0;
497  let Inst{25-16} = code_1;
498  let Inst{15-6}  = code_2;
499  let Inst{5-0}   = 0x07;
500}
501
502class BARRIER_MMR6_ENC<string instr_asm, bits<5> op> : MMR6Arch<instr_asm> {
503  bits<32> Inst;
504
505  let Inst{31-26} = 0x0;
506  let Inst{25-21} = 0x0;
507  let Inst{20-16} = 0x0;
508  let Inst{15-11} = op;
509  let Inst{10-6}  = 0x0;
510  let Inst{5-0}   = 0x0;
511}
512
513class POOL32A_EIDI_MMR6_ENC<string instr_asm, bits<10> funct>
514    : MMR6Arch<instr_asm> {
515  bits<32> Inst;
516  bits<5> rt; // Actually rs but we're sharing code with the standard encodings
517              // which call it rt
518
519  let Inst{31-26} = 0x00;
520  let Inst{25-21} = 0x00;
521  let Inst{20-16} = rt;
522  let Inst{15-6}  = funct;
523  let Inst{5-0}   = 0x3c;
524}
525
526class SHIFT_MMR6_ENC<string instr_asm, bits<10> funct, bit rotate>
527    : MMR6Arch<instr_asm> {
528  bits<5> rd;
529  bits<5> rt;
530  bits<5> shamt;
531
532  bits<32> Inst;
533
534  let Inst{31-26} = 0;
535  let Inst{25-21} = rd;
536  let Inst{20-16} = rt;
537  let Inst{15-11} = shamt;
538  let Inst{10}    = rotate;
539  let Inst{9-0}   = funct;
540}
541
542class SW32_FM_MMR6<string instr_asm, bits<6> op> : MMR6Arch<instr_asm> {
543  bits<5> rt;
544  bits<21> addr;
545
546  bits<32> Inst;
547
548  let Inst{31-26} = op;
549  let Inst{25-21} = rt;
550  let Inst{20-16} = addr{20-16};
551  let Inst{15-0}  = addr{15-0};
552}
553
554class POOL32F_ARITH_FM_MMR6<string instr_asm, bits<2> fmt, bits<8> funct>
555    : MMR6Arch<instr_asm>, MipsR6Inst {
556  bits<5> ft;
557  bits<5> fs;
558  bits<5> fd;
559
560  bits<32> Inst;
561
562  let Inst{31-26} = 0b010101;
563  let Inst{25-21} = ft;
564  let Inst{20-16} = fs;
565  let Inst{15-11} = fd;
566  let Inst{10}    = 0;
567  let Inst{9-8}   = fmt;
568  let Inst{7-0}   = funct;
569}
570
571class POOL32F_ARITHF_FM_MMR6<string instr_asm, bits<2> fmt, bits<9> funct>
572    : MMR6Arch<instr_asm>, MipsR6Inst {
573  bits<5> ft;
574  bits<5> fs;
575  bits<5> fd;
576
577  bits<32> Inst;
578
579  let Inst{31-26} = 0b010101;
580  let Inst{25-21} = ft;
581  let Inst{20-16} = fs;
582  let Inst{15-11} = fd;
583  let Inst{10-9}  = fmt;
584  let Inst{8-0}   = funct;
585}
586
587class POOL32F_MOV_NEG_FM_MMR6<string instr_asm, bits<2> fmt, bits<7> funct>
588    : MMR6Arch<instr_asm>, MipsR6Inst {
589  bits<5> ft;
590  bits<5> fs;
591
592  bits<32> Inst;
593
594  let Inst{31-26} = 0b010101;
595  let Inst{25-21} = ft;
596  let Inst{20-16} = fs;
597  let Inst{15}    = 0;
598  let Inst{14-13} = fmt;
599  let Inst{12-6}  = funct;
600  let Inst{5-0}   = 0b111011;
601}
602
603class POOL32F_MINMAX_FM<string instr_asm, bits<2> fmt, bits<9> funct>
604    : MMR6Arch<instr_asm>, MipsR6Inst {
605  bits<5> ft;
606  bits<5> fs;
607  bits<5> fd;
608
609  bits<32> Inst;
610
611  let Inst{31-26} = 0b010101;
612  let Inst{25-21} = ft;
613  let Inst{20-16} = fs;
614  let Inst{15-11} = fd;
615  let Inst{10-9} = fmt;
616  let Inst{8-0} = funct;
617}
618
619class POOL32F_CMP_FM<string instr_asm, bits<6> format, FIELD_CMP_COND Cond>
620    : MMR6Arch<instr_asm>, MipsR6Inst {
621  bits<5> ft;
622  bits<5> fs;
623  bits<5> fd;
624
625  bits<32> Inst;
626
627  let Inst{31-26} = 0b010101;
628  let Inst{25-21} = ft;
629  let Inst{20-16} = fs;
630  let Inst{15-11} = fd;
631  let Inst{10-6} = Cond.Value;
632  let Inst{5-0} = format;
633}
634
635class POOL32F_CVT_LW_FM<string instr_asm, bit fmt, bits<8> funct>
636    : MMR6Arch<instr_asm>, MipsR6Inst {
637  bits<5> ft;
638  bits<5> fs;
639
640  bits<32> Inst;
641  let Inst{31-26} = 0b010101;
642  let Inst{25-21} = ft;
643  let Inst{20-16} = fs;
644  let Inst{15} = 0;
645  let Inst{14} = fmt;
646  let Inst{13-6} = funct;
647  let Inst{5-0} = 0b111011;
648}
649
650class POOL32F_CVT_DS_FM<string instr_asm, bits<2> fmt, bits<7> funct>
651    : MMR6Arch<instr_asm>, MipsR6Inst {
652  bits<5> ft;
653  bits<5> fs;
654
655  bits<32> Inst;
656  let Inst{31-26} = 0b010101;
657  let Inst{25-21} = ft;
658  let Inst{20-16} = fs;
659  let Inst{15} = 0;
660  let Inst{14-13} = fmt;
661  let Inst{12-6} = funct;
662  let Inst{5-0} = 0b111011;
663}
664
665class POOL32F_ABS_FM_MMR6<string instr_asm, bits<2> fmt, bits<7> funct>
666    : MMR6Arch<instr_asm>, MipsR6Inst {
667  bits<5> ft;
668  bits<5> fs;
669
670  bits<32> Inst;
671
672  let Inst{31-26} = 0b010101;
673  let Inst{25-21} = ft;
674  let Inst{20-16} = fs;
675  let Inst{15}    = 0;
676  let Inst{14-13} = fmt;
677  let Inst{12-6}  = funct;
678  let Inst{5-0}   = 0b111011;
679}
680
681class POOL32F_MATH_FM_MMR6<string instr_asm, bits<1> fmt, bits<8> funct>
682    : MMR6Arch<instr_asm>, MipsR6Inst {
683  bits<5> ft;
684  bits<5> fs;
685
686  bits<32> Inst;
687
688  let Inst{31-26} = 0b010101;
689  let Inst{25-21} = ft;
690  let Inst{20-16} = fs;
691  let Inst{15}    = 0;
692  let Inst{14}    = fmt;
693  let Inst{13-6}  = funct;
694  let Inst{5-0}   = 0b111011;
695}
696
697class POOL16A_ADDU16_FM_MMR6 {
698  bits<3> rs;
699  bits<3> rt;
700  bits<3> rd;
701
702  bits<16> Inst;
703
704  let Inst{15-10} = 0b000001;
705  let Inst{9-7}   = rs;
706  let Inst{6-4}   = rt;
707  let Inst{3-1}   = rd;
708  let Inst{0}     = 0;
709}
710
711class POOL16C_AND16_FM_MMR6 {
712  bits<3> rt;
713  bits<3> rs;
714
715  bits<16> Inst;
716
717  let Inst{15-10} = 0b010001;
718  let Inst{9-7}   = rt;
719  let Inst{6-4}   = rs;
720  let Inst{3-0}   = 0b0001;
721}
722
723class POOL16C_NOT16_FM_MMR6 {
724  bits<3> rt;
725  bits<3> rs;
726
727  bits<16> Inst;
728
729  let Inst{15-10} = 0x11;
730  let Inst{9-7}   = rt;
731  let Inst{6-4}   = rs;
732  let Inst{3-0}   = 0b0000;
733}
734
735class POOL16C_MOVEP16_FM_MMR6 {
736  bits<3> dst_regs;
737  bits<3> rt;
738  bits<3> rs;
739
740  bits<16> Inst;
741
742  let Inst{15-10} = 0b010001;
743  let Inst{9-7}   = dst_regs;
744  let Inst{6-4}   = rt;
745  let Inst{3}     = rs{2};
746  let Inst{2}     = 0b1;
747  let Inst{1-0}   = rs{1-0};
748}
749
750class POOL16C_OR16_XOR16_FM_MMR6<bits<4> op> {
751  bits<3> rt;
752  bits<3> rs;
753
754  bits<16> Inst;
755
756  let Inst{15-10} = 0b010001;
757  let Inst{9-7}   = rt;
758  let Inst{6-4}   = rs;
759  let Inst{3-0}   = op;
760}
761
762class POOL16C_BREAKPOINT_FM_MMR6<bits<6> op> {
763  bits<4> code_;
764  bits<16> Inst;
765
766  let Inst{15-10} = 0b010001;
767  let Inst{9-6}   = code_;
768  let Inst{5-0}   = op;
769}
770
771class POOL16A_SUBU16_FM_MMR6 {
772  bits<3> rs;
773  bits<3> rt;
774  bits<3> rd;
775
776  bits<16> Inst;
777
778  let Inst{15-10} = 0b000001;
779  let Inst{9-7}   = rs;
780  let Inst{6-4}   = rt;
781  let Inst{3-1}   = rd;
782  let Inst{0}     = 0b1;
783}
784
785class POOL32A_WRPGPR_WSBH_FM_MMR6<string instr_asm, bits<10> funct>
786    : MMR6Arch<instr_asm>, MipsR6Inst {
787  bits<5> rt;
788  bits<5> rs;
789
790  bits<32> Inst;
791
792  let Inst{31-26} = 0x00;
793  let Inst{25-21} = rt;
794  let Inst{20-16} = rs;
795  let Inst{15-6}  = funct;
796  let Inst{5-0}   = 0x3c;
797}
798
799class POOL32F_RECIP_ROUND_FM_MMR6<string instr_asm, bits<1> fmt, bits<8> funct>
800    : MMR6Arch<instr_asm>, MipsR6Inst {
801  bits<5> ft;
802  bits<5> fs;
803
804  bits<32> Inst;
805
806  let Inst{31-26} = 0b010101;
807  let Inst{25-21} = ft;
808  let Inst{20-16} = fs;
809  let Inst{15}    = 0;
810  let Inst{14}    = fmt;
811  let Inst{13-6}  = funct;
812  let Inst{5-0}   = 0b111011;
813}
814
815class POOL32F_RINT_FM_MMR6<string instr_asm, bits<2> fmt> : MMR6Arch<instr_asm>,
816                                                            MipsR6Inst {
817  bits<5> fs;
818  bits<5> fd;
819
820  bits<32> Inst;
821
822  let Inst{31-26} = 0b010101;
823  let Inst{25-21} = fs;
824  let Inst{20-16} = fd;
825  let Inst{15-11} = 0;
826  let Inst{10-9}  = fmt;
827  let Inst{8-0}   = 0b000100000;
828}
829
830class POOL32F_SEL_FM_MMR6<string instr_asm, bits<2> fmt, bits<9> funct>
831    : MMR6Arch<instr_asm>, MipsR6Inst {
832  bits<5> ft;
833  bits<5> fs;
834  bits<5> fd;
835
836  bits<32> Inst;
837
838  let Inst{31-26} = 0b010101;
839  let Inst{25-21} = ft;
840  let Inst{20-16} = fs;
841  let Inst{15-11} = fd;
842  let Inst{10-9}  = fmt;
843  let Inst{8-0}   = funct;
844}
845
846class POOL32F_CLASS_FM_MMR6<string instr_asm, bits<2> fmt, bits<9> funct>
847    : MMR6Arch<instr_asm>, MipsR6Inst {
848  bits<5> fs;
849  bits<5> fd;
850
851  bits<32> Inst;
852
853  let Inst{31-26} = 0b010101;
854  let Inst{25-21} = fs;
855  let Inst{20-16} = fd;
856  let Inst{15-11} = 0b00000;
857  let Inst{10-9}  = fmt;
858  let Inst{8-0}   = funct;
859}
860
861class POOL32A_TLBINV_FM_MMR6<string instr_asm, bits<10> funct>
862    : MMR6Arch<instr_asm>, MipsR6Inst {
863  bits<32> Inst;
864
865  let Inst{31-26} = 0x0;
866  let Inst{25-16} = 0x0;
867  let Inst{15-6}  = funct;
868  let Inst{5-0}   = 0b111100;
869}
870
871class POOL32A_MFTC0_FM_MMR6<string instr_asm, bits<5> funct, bits<6> opcode>
872    : MMR6Arch<instr_asm>, MipsR6Inst {
873  bits<5> rt;
874  bits<5> rs;
875  bits<3> sel;
876
877  bits<32> Inst;
878
879  let Inst{31-26} = 0b000000;
880  let Inst{25-21} = rt;
881  let Inst{20-16} = rs;
882  let Inst{15-14} = 0;
883  let Inst{13-11} = sel;
884  let Inst{10-6}  = funct;
885  let Inst{5-0}   = opcode;
886}
887
888class POOL32A_GINV_FM_MMR6<string instr_asm, bits<2> ginv>
889    : MMR6Arch<instr_asm>, MipsR6Inst {
890  bits<5> rs;
891  bits<2> type;
892
893  bits<32> Inst;
894
895  let Inst{31-26} = 0x0;
896  let Inst{25-21} = 0x0;
897  let Inst{20-16} = rs;
898  let Inst{15-13} = 0b011;
899  let Inst{12-11} = ginv;
900  let Inst{10-9}  = type;
901  let Inst{8-6}   = 0b101;
902  let Inst{5-0}   = 0b111100;
903}
904
905class POOL32F_MFTC1_FM_MMR6<string instr_asm, bits<8> funct>
906    : MMR6Arch<instr_asm> {
907  bits<5> rt;
908  bits<5> fs;
909
910  bits<32> Inst;
911
912  let Inst{31-26} = 0b010101;
913  let Inst{25-21} = rt;
914  let Inst{20-16} = fs;
915  let Inst{15-14} = 0;
916  let Inst{13-6}  = funct;
917  let Inst{5-0}   = 0b111011;
918}
919
920class POOL32A_MFTC2_FM_MMR6<string instr_asm, bits<10> funct>
921    : MMR6Arch<instr_asm>, MipsR6Inst {
922  bits<5> rt;
923  bits<5> impl;
924
925  bits<32> Inst;
926
927  let Inst{31-26} = 0b000000;
928  let Inst{25-21} = rt;
929  let Inst{20-16} = impl;
930  let Inst{15-6}  = funct;
931  let Inst{5-0}   = 0b111100;
932}
933
934class CMP_BRANCH_2R_OFF16_FM_MMR6<string opstr, bits<6> funct>
935    : MipsR6Inst, MMR6Arch<opstr> {
936  bits<5> rt;
937  bits<5> rs;
938  bits<16> offset;
939
940  bits<32> Inst;
941
942  let Inst{31-26} = funct;
943  let Inst{25-21} = rt;
944  let Inst{20-16} = rs;
945  let Inst{15-0}  = offset;
946}
947
948class POOL32A_DVPEVP_FM_MMR6<string instr_asm, bits<10> funct>
949    : MMR6Arch<instr_asm>, MipsR6Inst {
950  bits<5> rs;
951
952  bits<32> Inst;
953
954  let Inst{31-26} = 0b000000;
955  let Inst{25-21} = 0b00000;
956  let Inst{20-16} = rs;
957  let Inst{15-6}  = funct;
958  let Inst{5-0}   = 0b111100;
959}
960
961class CMP_BRANCH_OFF21_FM_MMR6<string opstr, bits<6> funct> : MipsR6Inst {
962  bits<5> rs;
963  bits<21> offset;
964
965  bits<32> Inst;
966
967  let Inst{31-26} = funct;
968  let Inst{25-21} = rs;
969  let Inst{20-0} = offset;
970}
971
972class POOL32I_BRANCH_COP_1_2_FM_MMR6<string instr_asm, bits<5> funct>
973    : MMR6Arch<instr_asm> {
974  bits<5> rt;
975  bits<16> offset;
976
977  bits<32> Inst;
978
979  let Inst{31-26} = 0b010000;
980  let Inst{25-21} = funct;
981  let Inst{20-16} = rt;
982  let Inst{15-0}  = offset;
983}
984
985class LDWC1_SDWC1_FM_MMR6<string instr_asm, bits<6> funct>
986    : MMR6Arch<instr_asm> {
987  bits<5> ft;
988  bits<21> addr;
989  bits<5> base = addr{20-16};
990  bits<16> offset = addr{15-0};
991
992  bits<32> Inst;
993
994  let Inst{31-26} = funct;
995  let Inst{25-21} = ft;
996  let Inst{20-16} = base;
997  let Inst{15-0}  = offset;
998}
999
1000class POOL32B_LDWC2_SDWC2_FM_MMR6<string instr_asm, bits<4> funct>
1001    : MMR6Arch<instr_asm>, MipsR6Inst {
1002  bits<5> rt;
1003  bits<21> addr;
1004  bits<5> base = addr{20-16};
1005  bits<11> offset = addr{10-0};
1006
1007  bits<32> Inst;
1008
1009  let Inst{31-26} = 0b001000;
1010  let Inst{25-21} = rt;
1011  let Inst{20-16} = base;
1012  let Inst{15-12} = funct;
1013  let Inst{11}    = 0;
1014  let Inst{10-0}  = offset;
1015}
1016
1017class POOL32C_LL_E_SC_E_FM_MMR6<string instr_asm, bits<4> majorFunc,
1018                                bits<3> minorFunc> : MMR6Arch<instr_asm>,
1019                                                     MipsR6Inst {
1020  bits<5> rt;
1021  bits<21> addr;
1022  bits<5> base = addr{20-16};
1023  bits<9> offset = addr{8-0};
1024
1025  bits<32> Inst;
1026
1027  let Inst{31-26} = 0b011000;
1028  let Inst{25-21} = rt;
1029  let Inst{20-16} = base;
1030  let Inst{15-12} = majorFunc;
1031  let Inst{11-9}  = minorFunc;
1032  let Inst{8-0}   = offset;
1033}
1034