xref: /freebsd/contrib/llvm-project/llvm/lib/Target/M68k/M68kInstrInfo.td (revision 5e801ac66d24704442eba426ed13c3effb8a34e7)
1//== M68kInstrInfo.td - Main M68k Instruction Definition -*- 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/// \file
10/// This file describes the M68k instruction set, defining the instructions
11/// and properties of the instructions which are needed for code generation,
12/// machine code emission, and analysis.
13///
14//===----------------------------------------------------------------------===//
15
16include "M68kInstrFormats.td"
17
18//===----------------------------------------------------------------------===//
19// Profiles
20//===----------------------------------------------------------------------===//
21
22def MxSDT_CallSeqStart : SDCallSeqStart<[SDTCisVT<0, i32>, SDTCisVT<1, i32>]>;
23def MxSDT_CallSeqEnd   : SDCallSeqEnd<[SDTCisVT<0, i32>, SDTCisVT<1, i32>]>;
24
25def MxSDT_Call    : SDTypeProfile<0, -1, [SDTCisVT<0, iPTR>]>;
26
27def MxSDT_Ret     : SDTypeProfile<0, -1, [
28  /* ADJ */ SDTCisVT<0, i32>
29]>;
30
31def MxSDT_TCRet   : SDTypeProfile<0, 2, [SDTCisPtrTy<0>, SDTCisVT<1, i32>]>;
32
33def MxSDT_Wrapper : SDTypeProfile<1, 1, [SDTCisSameAs<0, 1>, SDTCisPtrTy<0>]>;
34
35def MxSDT_UnArithCCROut : SDTypeProfile<2, 1, [
36  /* RES */ SDTCisInt<0>,
37  /* CCR */ SDTCisVT<1, i8>,
38  /* OPD */ SDTCisSameAs<0, 2>
39]>;
40
41// RES, CCR <- op LHS, RHS
42def MxSDT_BiArithCCROut : SDTypeProfile<2, 2, [
43  /* RES */ SDTCisInt<0>,
44  /* CCR */ SDTCisVT<1, i8>,
45  /* LHS */ SDTCisSameAs<0, 2>,
46  /* RHS */ SDTCisSameAs<0, 3>
47]>;
48
49// RES, CCR <- op LHS, RHS, CCR
50def MxSDT_BiArithCCRInOut : SDTypeProfile<2, 3, [
51  /* RES 1 */ SDTCisInt<0>,
52  /*   CCR */ SDTCisVT<1, i8>,
53  /*   LHS */ SDTCisSameAs<0, 2>,
54  /*   RHS */ SDTCisSameAs<0, 3>,
55  /*   CCR */ SDTCisSameAs<1, 4>
56]>;
57
58// RES1, RES2, CCR <- op LHS, RHS
59def MxSDT_2BiArithCCROut : SDTypeProfile<3, 2, [
60  /* RES 1 */ SDTCisInt<0>,
61  /* RES 2 */ SDTCisSameAs<0, 1>,
62  /*   CCR */ SDTCisVT<1, i8>,
63  /*   LHS */ SDTCisSameAs<0, 2>,
64  /*   RHS */ SDTCisSameAs<0, 3>
65]>;
66
67def MxSDT_CmpTest : SDTypeProfile<1, 2, [
68   /* CCR */ SDTCisVT<0, i8>,
69   /* Ops */ SDTCisSameAs<1, 2>
70]>;
71
72def MxSDT_Cmov : SDTypeProfile<1, 4, [
73  /*  ARG */ SDTCisSameAs<0, 1>,
74  /*  ARG */ SDTCisSameAs<1, 2>,
75  /* Cond */ SDTCisVT<3, i8>,
76  /*  CCR */ SDTCisVT<4, i8>
77]>;
78
79def MxSDT_BrCond : SDTypeProfile<0, 3, [
80  /* Dest */ SDTCisVT<0, OtherVT>,
81  /* Cond */ SDTCisVT<1, i8>,
82  /*  CCR */ SDTCisVT<2, i8>
83]>;
84
85def MxSDT_SetCC : SDTypeProfile<1, 2, [
86  /* BOOL */ SDTCisVT<0, i8>,
87  /* Cond */ SDTCisVT<1, i8>,
88  /*  CCR */ SDTCisVT<2, i8>
89]>;
90
91def MxSDT_SetCC_C : SDTypeProfile<1, 2, [
92  /* BOOL */ SDTCisInt<0>,
93  /* Cond */ SDTCisVT<1, i8>,
94  /*  CCR */ SDTCisVT<2, i8>
95]>;
96
97
98def MxSDT_SEG_ALLOCA : SDTypeProfile<1, 1,[
99  /*  MEM */ SDTCisVT<0, iPTR>,
100  /* SIZE */ SDTCisVT<1, iPTR>
101]>;
102
103
104//===----------------------------------------------------------------------===//
105// Nodes
106//===----------------------------------------------------------------------===//
107
108def MxCallSeqStart : SDNode<"ISD::CALLSEQ_START", MxSDT_CallSeqStart,
109                            [SDNPHasChain, SDNPOutGlue]>;
110
111def MxCallSeqEnd   : SDNode<"ISD::CALLSEQ_END", MxSDT_CallSeqEnd,
112                            [SDNPHasChain, SDNPOptInGlue, SDNPOutGlue]>;
113
114def MxCall         : SDNode<"M68kISD::CALL", MxSDT_Call,
115                            [SDNPHasChain, SDNPOutGlue,
116                             SDNPOptInGlue, SDNPVariadic]>;
117
118def MxRet   : SDNode<"M68kISD::RET", MxSDT_Ret,
119                     [SDNPHasChain, SDNPOptInGlue, SDNPVariadic]>;
120
121def MxTCRet : SDNode<"M68kISD::TC_RETURN", MxSDT_TCRet,
122                     [SDNPHasChain,  SDNPOptInGlue, SDNPVariadic]>;
123
124def MxWrapper   : SDNode<"M68kISD::Wrapper",   MxSDT_Wrapper>;
125def MxWrapperPC : SDNode<"M68kISD::WrapperPC", MxSDT_Wrapper>;
126
127def MxAdd  : SDNode<"M68kISD::ADD",  MxSDT_BiArithCCROut, [SDNPCommutative]>;
128def MxSub  : SDNode<"M68kISD::SUB",  MxSDT_BiArithCCROut>;
129def MxOr   : SDNode<"M68kISD::OR",   MxSDT_BiArithCCROut, [SDNPCommutative]>;
130def MxXor  : SDNode<"M68kISD::XOR",  MxSDT_BiArithCCROut, [SDNPCommutative]>;
131def MxAnd  : SDNode<"M68kISD::AND",  MxSDT_BiArithCCROut, [SDNPCommutative]>;
132
133def MxAddX : SDNode<"M68kISD::ADDX", MxSDT_BiArithCCRInOut>;
134def MxSubX : SDNode<"M68kISD::SUBX", MxSDT_BiArithCCRInOut>;
135
136def MxSMul : SDNode<"M68kISD::SMUL", MxSDT_BiArithCCROut, [SDNPCommutative]>;
137def MxUMul : SDNode<"M68kISD::UMUL", MxSDT_2BiArithCCROut, [SDNPCommutative]>;
138
139def MxCmp     : SDNode<"M68kISD::CMP", MxSDT_CmpTest>;
140def MxBt      : SDNode<"M68kISD::BT",  MxSDT_CmpTest>;
141
142def MxCmov    : SDNode<"M68kISD::CMOV",        MxSDT_Cmov>;
143def MxBrCond  : SDNode<"M68kISD::BRCOND",      MxSDT_BrCond, [SDNPHasChain]>;
144def MxSetCC   : SDNode<"M68kISD::SETCC",       MxSDT_SetCC>;
145def MxSetCC_C : SDNode<"M68kISD::SETCC_CARRY", MxSDT_SetCC_C>;
146
147
148def MxSegAlloca : SDNode<"M68kISD::SEG_ALLOCA", MxSDT_SEG_ALLOCA,
149                         [SDNPHasChain]>;
150
151
152//===----------------------------------------------------------------------===//
153// Operands
154//===----------------------------------------------------------------------===//
155
156/// Size is the size of the data, either bits of a register or number of bits
157/// addressed in memory. Size id is a letter that identifies size.
158class MxSize<int num, string id, string full> {
159  int Num = num;
160  string Id = id;
161  string Full = full;
162}
163
164def MxSize8  : MxSize<8,  "b", "byte">;
165def MxSize16 : MxSize<16, "w", "word">;
166def MxSize32 : MxSize<32, "l", "long">;
167
168class MxOpClass<string name,
169                list<AsmOperandClass> superClasses = []> : AsmOperandClass {
170  let Name = name;
171  let ParserMethod = "parseMemOp";
172  let SuperClasses = superClasses;
173}
174
175def MxRegClass : MxOpClass<"Reg">;
176// Splitting asm register class to avoid ambiguous on operands'
177// MatchClassKind. For instance, without this separation,
178// both ADD32dd and ADD32dr has {MCK_RegClass, MCK_RegClass} for
179// their operands, which makes AsmParser unable to pick the correct
180// one in a deterministic way.
181let RenderMethod = "addRegOperands", SuperClasses = [MxRegClass]in {
182  def MxARegClass : MxOpClass<"AReg">;
183  def MxDRegClass : MxOpClass<"DReg">;
184}
185
186class MxOperand<ValueType vt, MxSize size, string letter, RegisterClass rc, dag pat = (null_frag)> {
187  ValueType VT = vt;
188  string Letter = letter;
189  MxSize Size = size;
190  RegisterClass RC = rc;
191  dag Pat = pat;
192}
193
194class MxRegOp<ValueType vt,
195              RegisterClass rc,
196              MxSize size,
197              string letter,
198              string pm = "printOperand">
199    : RegisterOperand<rc, pm>,
200      MxOperand<vt, size, letter, rc> {
201  let ParserMatchClass = MxRegClass;
202}
203
204// REGISTER DIRECT. The operand is in the data register specified by
205// the effective address register field.
206def MxXRD16 : MxRegOp<i16, XR16, MxSize16, "r">;
207def MxXRD32 : MxRegOp<i32, XR32, MxSize32, "r">;
208
209def MxXRD16_TC : MxRegOp<i16, XR16_TC, MxSize16, "r">;
210def MxXRD32_TC : MxRegOp<i32, XR32_TC, MxSize32, "r">;
211
212// DATA REGISTER DIRECT. The operand is in the data register specified by
213// the effective address register field.
214let ParserMatchClass = MxDRegClass in {
215  def MxDRD8  : MxRegOp<i8,  DR8,  MxSize8,  "d">;
216  def MxDRD16 : MxRegOp<i16, DR16, MxSize16, "d">;
217  def MxDRD32 : MxRegOp<i32, DR32, MxSize32, "d">;
218
219  def MxDRD16_TC : MxRegOp<i16, DR16_TC, MxSize16, "d">;
220  def MxDRD32_TC : MxRegOp<i32, DR32_TC, MxSize32, "d">;
221}
222
223// ADDRESS REGISTER DIRECT. The operand is in the address register specified by
224// the effective address register field.
225let ParserMatchClass = MxARegClass in {
226  def MxARD16 : MxRegOp<i16, AR16, MxSize16, "a">;
227  def MxARD32 : MxRegOp<i32, AR32, MxSize32, "a">;
228
229  def MxARD16_TC : MxRegOp<i16, AR16_TC, MxSize16, "a">;
230  def MxARD32_TC : MxRegOp<i32, AR32_TC, MxSize32, "a">;
231}
232
233class MxMemOp<dag ops, MxSize size, string letter,
234              string printMethod = "printOperand",
235              AsmOperandClass parserMatchClass = ImmAsmOperand>
236    : Operand<iPTR>, MxOperand<iPTR, size, letter, ?> {
237  let PrintMethod = printMethod;
238  let MIOperandInfo = ops;
239  let ParserMatchClass = parserMatchClass;
240  let OperandType = "OPERAND_MEMORY";
241}
242
243// ADDRESS REGISTER INDIRECT. The address of the operand is in the address
244// register specified by the register field. The reference is classified as
245// a data reference with the exception of the jump and jump-to-subroutine
246// instructions.
247def MxARI         : MxOpClass<"ARI">;
248def MxARI8        : MxMemOp<(ops AR32), MxSize8,  "j", "printARI8Mem", MxARI>;
249def MxARI16       : MxMemOp<(ops AR32), MxSize16, "j", "printARI16Mem", MxARI>;
250def MxARI32       : MxMemOp<(ops AR32), MxSize32, "j", "printARI32Mem", MxARI>;
251
252def MxARI8_TC     : MxMemOp<(ops AR32_TC), MxSize8,  "j", "printARI8Mem", MxARI>;
253def MxARI16_TC    : MxMemOp<(ops AR32_TC), MxSize16, "j", "printARI16Mem", MxARI>;
254def MxARI32_TC    : MxMemOp<(ops AR32_TC), MxSize32, "j", "printARI32Mem", MxARI>;
255
256// ADDRESS REGISTER INDIRECT WITH POSTINCREMENT. The address of the operand is
257// in the address register specified by the register field. After the operand
258// address is used, it is incremented by one, two, or four depending upon whether
259// the size of the operand is byte, word, or long word. If the address register
260// is the stack pointer and the operand size is byte, the address is incremented
261// by two rather than one to keep the stack pointer on a word boundary.
262// The reference is classified as a data reference.
263def MxARIPI       : MxOpClass<"ARIPI">;
264def MxARIPI8      : MxMemOp<(ops AR32), MxSize8,  "o", "printARIPI8Mem", MxARIPI>;
265def MxARIPI16     : MxMemOp<(ops AR32), MxSize16, "o", "printARIPI16Mem", MxARIPI>;
266def MxARIPI32     : MxMemOp<(ops AR32), MxSize32, "o", "printARIPI32Mem", MxARIPI>;
267
268def MxARIPI8_TC   : MxMemOp<(ops AR32_TC), MxSize8,  "o", "printARIPI8Mem", MxARIPI>;
269def MxARIPI16_TC  : MxMemOp<(ops AR32_TC), MxSize16, "o", "printARIPI16Mem", MxARIPI>;
270def MxARIPI32_TC  : MxMemOp<(ops AR32_TC), MxSize32, "o", "printARIPI32Mem", MxARIPI>;
271
272// ADDRESS REGISTER INDIRECT WITH PREDECREMENT. The address of the operand is in
273// the address register specified by the register field. Before the operand
274// address is used, it is decremented by one, two, or four depending upon whether
275// the operand size is byte, word, or long word. If the address register is
276// the stack pointer and the operand size is byte, the address is decremented by
277// two rather than one to keep the stack pointer on a word boundary.
278// The reference is classified as a data reference.
279def MxARIPD       : MxOpClass<"ARIPD">;
280def MxARIPD8      : MxMemOp<(ops AR32), MxSize8,  "e", "printARIPD8Mem", MxARIPD>;
281def MxARIPD16     : MxMemOp<(ops AR32), MxSize16, "e", "printARIPD16Mem", MxARIPD>;
282def MxARIPD32     : MxMemOp<(ops AR32), MxSize32, "e", "printARIPD32Mem", MxARIPD>;
283
284def MxARIPD8_TC   : MxMemOp<(ops AR32_TC), MxSize8,  "e", "printARIPD8Mem", MxARIPD>;
285def MxARIPD16_TC  : MxMemOp<(ops AR32_TC), MxSize16, "e", "printARIPD16Mem", MxARIPD>;
286def MxARIPD32_TC  : MxMemOp<(ops AR32_TC), MxSize32, "e", "printARIPD32Mem", MxARIPD>;
287
288// ADDRESS REGISTER INDIRECT WITH DISPLACEMENT. This addressing mode requires one
289// word of extension. The address of the operand is the sum of the address in
290// the address register and the sign-extended 16-bit displacement integer in the
291// extension word. The reference is classified as a data reference with the
292// exception of the jump and jump-to-subroutine instructions.
293def MxARID        : MxOpClass<"ARID">;
294def MxARID8       : MxMemOp<(ops i16imm, AR32), MxSize8,  "p", "printARID8Mem", MxARID>;
295def MxARID16      : MxMemOp<(ops i16imm, AR32), MxSize16, "p", "printARID16Mem", MxARID>;
296def MxARID32      : MxMemOp<(ops i16imm, AR32), MxSize32, "p", "printARID32Mem", MxARID>;
297
298def MxARID8_TC    : MxMemOp<(ops i16imm, AR32_TC), MxSize8,  "p", "printARID8Mem", MxARID>;
299def MxARID16_TC   : MxMemOp<(ops i16imm, AR32_TC), MxSize16, "p", "printARID16Mem", MxARID>;
300def MxARID32_TC   : MxMemOp<(ops i16imm, AR32_TC), MxSize32, "p", "printARID32Mem", MxARID>;
301
302// ADDRESS REGISTER INDIRECT WITH INDEX. This addressing mode requires one word
303// of extension. The address of the operand is the sum of the address in the
304// address register, the signextended displacement integer in the low order eight
305// bits of the extension word, and the contents of the index register.
306// The reference is classified as a data reference with the exception of the
307// jump and jump-to-subroutine instructions
308def MxARII       : MxOpClass<"ARII">;
309def MxARII8      : MxMemOp<(ops i8imm, AR32, XR32), MxSize8,  "f", "printARII8Mem", MxARII>;
310def MxARII16     : MxMemOp<(ops i8imm, AR32, XR32), MxSize16, "f", "printARII16Mem", MxARII>;
311def MxARII32     : MxMemOp<(ops i8imm, AR32, XR32), MxSize32, "f", "printARII32Mem", MxARII>;
312
313def MxARII8_TC   : MxMemOp<(ops i8imm, AR32_TC, XR32_TC), MxSize8,  "f", "printARII8Mem", MxARII>;
314def MxARII16_TC  : MxMemOp<(ops i8imm, AR32_TC, XR32_TC), MxSize16, "f", "printARII16Mem", MxARII>;
315def MxARII32_TC  : MxMemOp<(ops i8imm, AR32_TC, XR32_TC), MxSize32, "f", "printARII32Mem", MxARII>;
316
317// ABSOLUTE SHORT ADDRESS. This addressing mode requires one word of extension.
318// The address of the operand is the extension word. The 16-bit address is sign
319// extended before it is used.  The reference is classified as a data reference
320// with the exception of the jump and jump-tosubroutine instructions.
321def MxAddr     : MxOpClass<"Addr">;
322let RenderMethod = "addAddrOperands" in {
323  // This hierarchy ensures Addr8 will always be parsed
324  // before other larger-width variants.
325  def MxAddr32   : MxOpClass<"Addr32", [MxAddr]>;
326  def MxAddr16   : MxOpClass<"Addr16", [MxAddr32]>;
327  def MxAddr8    : MxOpClass<"Addr8",  [MxAddr16]>;
328}
329
330def MxAS8      : MxMemOp<(ops OtherVT), MxSize8,  "B", "printAS8Mem",  MxAddr8>;
331def MxAS16     : MxMemOp<(ops OtherVT), MxSize16, "B", "printAS16Mem", MxAddr16>;
332def MxAS32     : MxMemOp<(ops OtherVT), MxSize32, "B", "printAS32Mem", MxAddr32>;
333
334// ABSOLUTE LONG ADDRESS. This addressing mode requires two words of extension.
335// The address of the operand is developed by the concatenation of the extension
336// words. The high order part of the address is the first extension word; the low
337// order part of the address is the second extension word. The reference is
338// classified as a data reference with the exception of the jump and jump
339// to-subroutine instructions.
340def MxAL8      : MxMemOp<(ops OtherVT), MxSize8,  "b", "printAL8Mem",  MxAddr8>;
341def MxAL16     : MxMemOp<(ops OtherVT), MxSize16, "b", "printAL16Mem", MxAddr16>;
342def MxAL32     : MxMemOp<(ops OtherVT), MxSize32, "b", "printAL32Mem", MxAddr32>;
343
344def MxPCD : MxOpClass<"PCD">;
345def MxPCI : MxOpClass<"PCI">;
346
347let OperandType = "OPERAND_PCREL" in {
348// PROGRAM COUNTER WITH DISPLACEMENT. This addressing mode requires one word of
349// extension. The address of the operand is the sum of the address in the program
350// counter and the Sign-extended 16-bit displacement integer in the extension
351// word. The value in the program counter is the address of the extension word.
352// The reference is classified as a program reference.
353def MxPCD8     : MxMemOp<(ops i16imm), MxSize8,  "q", "printPCD8Mem", MxPCD>;
354def MxPCD16    : MxMemOp<(ops i16imm), MxSize16, "q", "printPCD16Mem", MxPCD>;
355def MxPCD32    : MxMemOp<(ops i16imm), MxSize32, "q", "printPCD32Mem", MxPCD>;
356
357// PROGRAM COUNTER WITH INDEX. This addressing mode requires one word of
358// extension. The address is the sum of the address in the program counter, the
359// sign-extended displacement integer in the lower eight bits of the extension
360// word, and the contents of the index register.  The value in the program
361// counter is the address of the extension word. This reference is classified as
362// a program reference.
363def MxPCI8   : MxMemOp<(ops i8imm, XR32), MxSize8,  "k", "printPCI8Mem", MxPCI>;
364def MxPCI16  : MxMemOp<(ops i8imm, XR32), MxSize16, "k", "printPCI16Mem", MxPCI>;
365def MxPCI32  : MxMemOp<(ops i8imm, XR32), MxSize32, "k", "printPCI32Mem", MxPCI>;
366} // OPERAND_PCREL
367
368def MxImm : AsmOperandClass {
369  let Name = "MxImm";
370  let PredicateMethod = "isImm";
371  let RenderMethod = "addImmOperands";
372  let ParserMethod = "parseImm";
373}
374
375class MxOp<ValueType vt, MxSize size, string letter>
376    : Operand<vt>,
377      MxOperand<vt, size, letter, ?> {
378  let ParserMatchClass = MxImm;
379}
380
381let OperandType = "OPERAND_IMMEDIATE",
382    PrintMethod = "printImmediate" in {
383// IMMEDIATE DATA. This addressing mode requires either one or two words of
384// extension depending on the size of the operation.
385//     Byte Operation - operand is low order byte of extension word
386//     Word Operation - operand is extension word
387//     Long Word Operation - operand is in the two extension words,
388//                           high order 16 bits are in the first
389//                           extension word, low order 16 bits are
390//                           in the second extension word.
391def Mxi8imm  : MxOp<i8,  MxSize8,  "i">;
392def Mxi16imm : MxOp<i16, MxSize16, "i">;
393def Mxi32imm : MxOp<i32, MxSize32, "i">;
394} // OPERAND_IMMEDIATE
395
396class MxBrTargetOperand<int N> : Operand<OtherVT> {
397  let OperandType = "OPERAND_PCREL";
398  let PrintMethod = "printPCRelImm";
399  let ParserMatchClass = !cast<AsmOperandClass>("MxAddr"#N);
400}
401// Branch targets have OtherVT type and print as pc-relative values.
402def MxBrTarget8  : MxBrTargetOperand<8>;
403def MxBrTarget16 : MxBrTargetOperand<16>;
404def MxBrTarget32 : MxBrTargetOperand<32>;
405
406// Used with MOVEM
407def MxMoveMaskClass : MxOpClass<"MoveMask">;
408def MxMoveMask : MxOp<i16, MxSize16, "m"> {
409  let OperandType = "OPERAND_IMMEDIATE";
410  let PrintMethod = "printMoveMask";
411  let ParserMatchClass = MxMoveMaskClass;
412}
413
414//===----------------------------------------------------------------------===//
415// Predicates
416//===----------------------------------------------------------------------===//
417
418def SmallCode    : Predicate<"TM.getCodeModel() == CodeModel::Small">;
419def KernelCode   : Predicate<"TM.getCodeModel() == CodeModel::Kernel">;
420def FarData      : Predicate<"TM.getCodeModel() != CodeModel::Small &&"
421                             "TM.getCodeModel() != CodeModel::Kernel">;
422def NearData     : Predicate<"TM.getCodeModel() == CodeModel::Small ||"
423                             "TM.getCodeModel() == CodeModel::Kernel">;
424def IsPIC        : Predicate<"TM.isPositionIndependent()">;
425def IsNotPIC     : Predicate<"!TM.isPositionIndependent()">;
426def IsM68000     : Predicate<"Subtarget.IsM68000()">;
427def IsM68010     : Predicate<"Subtarget.IsM68010()">;
428def IsM68020     : Predicate<"Subtarget.IsM68020()">;
429def IsM68030     : Predicate<"Subtarget.IsM68030()">;
430def IsM68040     : Predicate<"Subtarget.IsM68040()">;
431
432
433//===----------------------------------------------------------------------===//
434// Condition Codes
435//
436// These MUST be kept in sync with codes enum in M68kInstrInfo.h
437//===----------------------------------------------------------------------===//
438
439def MxCONDt   : PatLeaf<(i8 0)>;  // True
440def MxCONDf   : PatLeaf<(i8 1)>;  // False
441def MxCONDhi  : PatLeaf<(i8 2)>;  // High
442def MxCONDls  : PatLeaf<(i8 3)>;  // Less or Same
443def MxCONDcc  : PatLeaf<(i8 4)>;  // Carry Clear
444def MxCONDcs  : PatLeaf<(i8 5)>;  // Carry Set
445def MxCONDne  : PatLeaf<(i8 6)>;  // Not Equal
446def MxCONDeq  : PatLeaf<(i8 7)>;  // Equal
447def MxCONDvc  : PatLeaf<(i8 8)>;  // Overflow Clear
448def MxCONDvs  : PatLeaf<(i8 9)>;  // Overflow Set
449def MxCONDpl  : PatLeaf<(i8 10)>; // Plus
450def MxCONDmi  : PatLeaf<(i8 11)>; // Minus
451def MxCONDge  : PatLeaf<(i8 12)>; // Greater or Equal
452def MxCONDlt  : PatLeaf<(i8 13)>; // Less Than
453def MxCONDgt  : PatLeaf<(i8 14)>; // Greater Than
454def MxCONDle  : PatLeaf<(i8 15)>; // Less or Equal
455
456
457//===----------------------------------------------------------------------===//
458// Complex Patterns
459//===----------------------------------------------------------------------===//
460
461// NOTE Though this CP is not strictly necessarily it will simplify instruciton
462// definitions
463def MxCP_ARI   : ComplexPattern<iPTR, 1, "SelectARI",
464                                [], [SDNPWantParent]>;
465
466def MxCP_ARIPI : ComplexPattern<iPTR, 1, "SelectARIPI",
467                                [], [SDNPWantParent]>;
468
469def MxCP_ARIPD : ComplexPattern<iPTR, 1, "SelectARIPD",
470                                [], [SDNPWantParent]>;
471
472def MxCP_ARID  : ComplexPattern<iPTR, 2, "SelectARID",
473                                [add, sub, mul, or, shl, frameindex],
474                                [SDNPWantParent]>;
475
476def MxCP_ARII  : ComplexPattern<iPTR, 3, "SelectARII",
477                                [add, sub, mul, or, shl, frameindex],
478                                [SDNPWantParent]>;
479
480def MxCP_AL    : ComplexPattern<iPTR, 1, "SelectAL",
481                                [add, sub, mul, or, shl],
482                                [SDNPWantParent]>;
483
484def MxCP_PCD   : ComplexPattern<iPTR, 1, "SelectPCD",
485                                [add, sub, mul, or, shl],
486                                [SDNPWantParent]>;
487
488def MxCP_PCI   : ComplexPattern<iPTR, 2, "SelectPCI",
489                                [add, sub, mul, or, shl], [SDNPWantParent]>;
490
491
492//===----------------------------------------------------------------------===//
493// Pattern Fragments
494//===----------------------------------------------------------------------===//
495
496def MximmSExt8  : PatLeaf<(i8  imm)>;
497def MximmSExt16 : PatLeaf<(i16 imm)>;
498def MximmSExt32 : PatLeaf<(i32 imm)>;
499
500// Used for Shifts and Rotations, since M68k immediates in these instructions
501// are 1 <= i <= 8. Generally, if immediate is bigger than 8 it will be moved
502// to a register and then an operation is performed.
503//
504// TODO Need to evaluate whether splitting one big shift(or rotate)
505// into a few smaller is faster than doing a move, if so do custom lowering
506def Mximm8_1to8   : ImmLeaf<i8,  [{ return Imm >= 1 && Imm <= 8; }]>;
507def Mximm16_1to8  : ImmLeaf<i16, [{ return Imm >= 1 && Imm <= 8; }]>;
508def Mximm32_1to8  : ImmLeaf<i32, [{ return Imm >= 1 && Imm <= 8; }]>;
509
510// Helper fragments for loads.
511// It's always safe to treat a anyext i16 load as a i32 load if the i16 is
512// known to be 32-bit aligned or better. Ditto for i8 to i16.
513def Mxloadi16 : PatFrag<(ops node:$ptr), (i16 (unindexedload node:$ptr)), [{
514  LoadSDNode *LD = cast<LoadSDNode>(N);
515  ISD::LoadExtType ExtType = LD->getExtensionType();
516  if (ExtType == ISD::NON_EXTLOAD)
517    return true;
518  if (ExtType == ISD::EXTLOAD)
519    return LD->getAlignment() >= 2 && !LD->isSimple();
520  return false;
521}]>;
522
523def Mxloadi32 : PatFrag<(ops node:$ptr), (i32 (unindexedload node:$ptr)), [{
524  LoadSDNode *LD = cast<LoadSDNode>(N);
525  ISD::LoadExtType ExtType = LD->getExtensionType();
526  if (ExtType == ISD::NON_EXTLOAD)
527    return true;
528  if (ExtType == ISD::EXTLOAD)
529    return LD->getAlignment() >= 4 && !LD->isSimple();
530  return false;
531}]>;
532
533def Mxloadi8         : PatFrag<(ops node:$ptr), (i8  (load node:$ptr))>;
534
535def MxSExtLoadi16i8  : PatFrag<(ops node:$ptr), (i16 (sextloadi8 node:$ptr))>;
536def MxSExtLoadi32i8  : PatFrag<(ops node:$ptr), (i32 (sextloadi8 node:$ptr))>;
537def MxSExtLoadi32i16 : PatFrag<(ops node:$ptr), (i32 (sextloadi16 node:$ptr))>;
538
539def MxZExtLoadi8i1   : PatFrag<(ops node:$ptr), (i8  (zextloadi1 node:$ptr))>;
540def MxZExtLoadi16i1  : PatFrag<(ops node:$ptr), (i16 (zextloadi1 node:$ptr))>;
541def MxZExtLoadi32i1  : PatFrag<(ops node:$ptr), (i32 (zextloadi1 node:$ptr))>;
542def MxZExtLoadi16i8  : PatFrag<(ops node:$ptr), (i16 (zextloadi8 node:$ptr))>;
543def MxZExtLoadi32i8  : PatFrag<(ops node:$ptr), (i32 (zextloadi8 node:$ptr))>;
544def MxZExtLoadi32i16 : PatFrag<(ops node:$ptr), (i32 (zextloadi16 node:$ptr))>;
545
546def MxExtLoadi8i1    : PatFrag<(ops node:$ptr), (i8  (extloadi1 node:$ptr))>;
547def MxExtLoadi16i1   : PatFrag<(ops node:$ptr), (i16 (extloadi1 node:$ptr))>;
548def MxExtLoadi32i1   : PatFrag<(ops node:$ptr), (i32 (extloadi1 node:$ptr))>;
549def MxExtLoadi16i8   : PatFrag<(ops node:$ptr), (i16 (extloadi8 node:$ptr))>;
550def MxExtLoadi32i8   : PatFrag<(ops node:$ptr), (i32 (extloadi8 node:$ptr))>;
551def MxExtLoadi32i16  : PatFrag<(ops node:$ptr), (i32 (extloadi16 node:$ptr))>;
552
553
554//===----------------------------------------------------------------------===//
555// Type Fixtures
556//
557// Type Fixtures are ValueType related information sets that usually go together
558//===----------------------------------------------------------------------===//
559
560// TODO make it folded like MxType8.F.Op nad MxType8.F.Pat
561// TODO move strings into META subclass
562// vt: Type of data this fixture refers to
563// prefix: Prefix used to identify type
564// postfix: Prefix used to qualify type
565class MxType<ValueType vt, string prefix, string postfix,
566             // rLet: Register letter
567             // rOp:  Supported any register operand
568             string rLet, MxOperand rOp,
569             // jOp:  Supported ARI operand
570             // jPat: What ARI pattern to use
571             MxOperand jOp, ComplexPattern jPat,
572             // oOp:  Supported ARIPI operand
573             // oPat: What ARIPI pattern is used
574             MxOperand oOp, ComplexPattern oPat,
575             // eOp:  Supported ARIPD operand
576             // ePat: What ARIPD pattern is used
577             MxOperand eOp, ComplexPattern ePat,
578             // pOp:  Supported ARID operand
579             // pPat: What ARID pattern is used
580             MxOperand pOp, ComplexPattern pPat,
581             // fOp:  Supported ARII operand
582             // fPat: What ARII pattern is used
583             MxOperand fOp, ComplexPattern fPat,
584             // bOp:  Supported absolute operand
585             // bPat: What absolute pattern is used
586             MxOperand bOp, ComplexPattern bPat,
587             // qOp:  Supported PCD operand
588             // qPat: What PCD pattern is used
589             MxOperand qOp, ComplexPattern qPat,
590             // kOp:  Supported PCD operand
591             // kPat: What PCD pattern is used
592             MxOperand kOp, ComplexPattern kPat,
593             // iOp:  Supported immediate operand
594             // iPat: What immediate pattern is used
595             MxOperand iOp, PatFrag iPat,
596             // load: What load operation is used with MEM
597             PatFrag load> {
598  int Size = vt.Size;
599  ValueType VT = vt;
600  string Prefix = prefix;
601  string Postfix = postfix;
602
603  string RLet = rLet;
604  MxOperand ROp = rOp;
605
606  MxOperand JOp = jOp;
607  ComplexPattern JPat = jPat;
608
609  MxOperand OOp = oOp;
610  ComplexPattern OPat = oPat;
611
612  MxOperand EOp = eOp;
613  ComplexPattern EPat = ePat;
614
615  MxOperand POp = pOp;
616  ComplexPattern PPat = pPat;
617
618  MxOperand FOp = fOp;
619  ComplexPattern FPat = fPat;
620
621  MxOperand BOp = bOp;
622  ComplexPattern BPat = bPat;
623
624  MxOperand QOp = qOp;
625  ComplexPattern QPat = qPat;
626
627  MxOperand KOp = kOp;
628  ComplexPattern KPat = kPat;
629
630  MxOperand IOp = iOp;
631  PatFrag IPat = iPat;
632
633  PatFrag Load = load;
634}
635
636class MxType8Class<string rLet, MxOperand reg>
637    : MxType<i8, "b", "", rLet, reg,
638             MxARI8,   MxCP_ARI,
639             MxARIPI8, MxCP_ARIPI,
640             MxARIPD8, MxCP_ARIPD,
641             MxARID8,  MxCP_ARID,
642             MxARII8,  MxCP_ARII,
643             MxAL8,    MxCP_AL,
644             MxPCD8,   MxCP_PCD,
645             MxPCI8,   MxCP_PCI,
646             Mxi8imm,  MximmSExt8,
647             Mxloadi8>;
648
649def MxType8 : MxType8Class<?,?>;
650
651class MxType16Class<string rLet, MxOperand reg>
652    : MxType<i16, "w", "", rLet, reg,
653             MxARI16,   MxCP_ARI,
654             MxARIPI16, MxCP_ARIPI,
655             MxARIPD16, MxCP_ARIPD,
656             MxARID16,  MxCP_ARID,
657             MxARII16,  MxCP_ARII,
658             MxAL16,    MxCP_AL,
659             MxPCD16,   MxCP_PCD,
660             MxPCI16,   MxCP_PCI,
661             Mxi16imm,  MximmSExt16,
662             Mxloadi16>;
663
664def MxType16 : MxType16Class<?,?>;
665
666class MxType32Class<string rLet, MxOperand reg>
667    : MxType<i32, "l", "", rLet, reg,
668             MxARI32,   MxCP_ARI,
669             MxARIPI32, MxCP_ARIPI,
670             MxARIPD32, MxCP_ARIPD,
671             MxARID32,  MxCP_ARID,
672             MxARII32,  MxCP_ARII,
673             MxAL32,    MxCP_AL,
674             MxPCD32,   MxCP_PCD,
675             MxPCI32,   MxCP_PCI,
676             Mxi32imm,  MximmSExt32,
677             Mxloadi32>;
678
679def MxType32 : MxType32Class<?,?>;
680
681
682def MxType8d : MxType8Class<"d", MxDRD8>;
683
684def MxType16d : MxType16Class<"d", MxDRD16>;
685def MxType16a : MxType16Class<"a", MxARD16>;
686def MxType16r : MxType16Class<"r", MxXRD16>;
687def MxType32d : MxType32Class<"d", MxDRD32>;
688def MxType32a : MxType32Class<"a", MxARD32>;
689def MxType32r : MxType32Class<"r", MxXRD32>;
690
691let Postfix = "_TC" in {
692def MxType16d_TC : MxType16Class<"d", MxDRD16_TC>;
693def MxType16a_TC : MxType16Class<"a", MxARD16_TC>;
694def MxType16r_TC : MxType16Class<"r", MxXRD16_TC>;
695def MxType32d_TC : MxType32Class<"d", MxDRD32_TC>;
696def MxType32a_TC : MxType32Class<"a", MxARD32_TC>;
697def MxType32r_TC : MxType32Class<"r", MxXRD32_TC>;
698}
699
700
701//===----------------------------------------------------------------------===//
702// Subsystems
703//===----------------------------------------------------------------------===//
704
705include "M68kInstrData.td"
706include "M68kInstrShiftRotate.td"
707include "M68kInstrBits.td"
708include "M68kInstrArithmetic.td"
709include "M68kInstrControl.td"
710
711include "M68kInstrCompiler.td"
712