| Misha Brukman | ffe9968 | 2005-02-05 02:24:26 +0000 | [diff] [blame] | 1 | //===- AlphaInstrFormats.td - Alpha Instruction Formats ----*- tablegen -*-===// | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 2 | // | 
|  | 3 | //                     The LLVM Compiler Infrastructure | 
|  | 4 | // | 
|  | 5 | // This file was developed by the LLVM research group and is distributed under | 
|  | 6 | // the University of Illinois Open Source License. See LICENSE.TXT for details. | 
|  | 7 | // | 
|  | 8 | //===----------------------------------------------------------------------===// | 
|  | 9 | // | 
|  | 10 | // | 
|  | 11 | //===----------------------------------------------------------------------===// | 
|  | 12 |  | 
|  | 13 | //3.3: | 
|  | 14 | //Memory | 
|  | 15 | //Branch | 
|  | 16 | //Operate | 
|  | 17 | //Floating-point | 
|  | 18 | //PALcode | 
|  | 19 |  | 
| Andrew Lenharth | 7b69867 | 2005-10-20 00:28:31 +0000 | [diff] [blame] | 20 | def u8imm   : Operand<i64>; | 
|  | 21 | def s14imm  : Operand<i64>; | 
|  | 22 | def s16imm  : Operand<i64>; | 
|  | 23 | def s21imm  : Operand<i64>; | 
| Andrew Lenharth | 02daecc | 2005-07-22 20:50:29 +0000 | [diff] [blame] | 24 | def s64imm  : Operand<i64>; | 
|  | 25 |  | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 26 | //===----------------------------------------------------------------------===// | 
|  | 27 | // Instruction format superclass | 
|  | 28 | //===----------------------------------------------------------------------===// | 
| Andrew Lenharth | 97a7fcf | 2005-11-09 19:17:08 +0000 | [diff] [blame] | 29 | // Alpha instruction baseline | 
|  | 30 | class InstAlphaAlt<bits<6> op, string asmstr> : Instruction { | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 31 | field bits<32> Inst; | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 32 | let Namespace = "Alpha"; | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 33 | let AsmString = asmstr; | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 34 | let Inst{31-26} = op; | 
|  | 35 | } | 
|  | 36 |  | 
| Andrew Lenharth | 97a7fcf | 2005-11-09 19:17:08 +0000 | [diff] [blame] | 37 | class InstAlpha<bits<6> op, dag OL, string asmstr> | 
|  | 38 | : InstAlphaAlt<op, asmstr> { // Alpha instruction baseline | 
|  | 39 | let OperandList = OL; | 
|  | 40 | } | 
|  | 41 |  | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 42 | //3.3.1 | 
| Andrew Lenharth | b9aaea3 | 2005-12-24 07:34:33 +0000 | [diff] [blame] | 43 | class MForm<bits<6> opcode, bit store, bit load, string asmstr, list<dag> pattern> | 
| Andrew Lenharth | 636e1ae | 2005-12-24 03:41:56 +0000 | [diff] [blame] | 44 | : InstAlphaAlt<opcode, asmstr> { | 
|  | 45 | let Pattern = pattern; | 
| Andrew Lenharth | b9aaea3 | 2005-12-24 07:34:33 +0000 | [diff] [blame] | 46 | let isStore = store; | 
|  | 47 | let isLoad = load; | 
| Andrew Lenharth | 153f808 | 2006-01-26 03:22:07 +0000 | [diff] [blame] | 48 | let Defs = [R28]; //We may use this for frame index calculations, so reserve it here | 
| Andrew Lenharth | 636e1ae | 2005-12-24 03:41:56 +0000 | [diff] [blame] | 49 |  | 
|  | 50 | bits<5> Ra; | 
|  | 51 | bits<16> disp; | 
|  | 52 | bits<5> Rb; | 
|  | 53 |  | 
|  | 54 | let Inst{25-21} = Ra; | 
|  | 55 | let Inst{20-16} = Rb; | 
|  | 56 | let Inst{15-0} = disp; | 
|  | 57 | } | 
| Andrew Lenharth | 6db615d | 2005-11-30 07:19:56 +0000 | [diff] [blame] | 58 |  | 
| Andrew Lenharth | 01aa563 | 2005-11-11 16:47:30 +0000 | [diff] [blame] | 59 | class MfcForm<bits<6> opcode, bits<16> fc, string asmstr> | 
| Andrew Lenharth | 34380b7 | 2006-01-16 21:22:38 +0000 | [diff] [blame] | 60 | : InstAlpha<opcode, (ops GPRC:$RA), asmstr> { | 
| Andrew Lenharth | 01aa563 | 2005-11-11 16:47:30 +0000 | [diff] [blame] | 61 | bits<5> Ra; | 
| Andrew Lenharth | 01aa563 | 2005-11-11 16:47:30 +0000 | [diff] [blame] | 62 |  | 
|  | 63 | let Inst{25-21} = Ra; | 
| Andrew Lenharth | 34380b7 | 2006-01-16 21:22:38 +0000 | [diff] [blame] | 64 | let Inst{20-16} = 0; | 
| Andrew Lenharth | 01aa563 | 2005-11-11 16:47:30 +0000 | [diff] [blame] | 65 | let Inst{15-0} = fc; | 
|  | 66 | } | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 67 |  | 
| Andrew Lenharth | 02daecc | 2005-07-22 20:50:29 +0000 | [diff] [blame] | 68 | class MbrForm<bits<6> opcode, bits<2> TB, dag OL, string asmstr> : InstAlpha<opcode, OL, asmstr> { | 
|  | 69 | bits<5> Ra; | 
|  | 70 | bits<5> Rb; | 
|  | 71 | bits<14> disp; | 
|  | 72 |  | 
|  | 73 | let Inst{25-21} = Ra; | 
|  | 74 | let Inst{20-16} = Rb; | 
|  | 75 | let Inst{15-14} = TB; | 
|  | 76 | let Inst{13-0} = disp; | 
|  | 77 | } | 
|  | 78 |  | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 79 | //3.3.2 | 
| Andrew Lenharth | f520093 | 2005-12-25 17:36:48 +0000 | [diff] [blame] | 80 | def target : Operand<OtherVT> {} | 
| Andrew Lenharth | 29b7ef0 | 2005-12-06 20:40:34 +0000 | [diff] [blame] | 81 | let isBranch = 1, isTerminator = 1 in | 
| Andrew Lenharth | f520093 | 2005-12-25 17:36:48 +0000 | [diff] [blame] | 82 | class BFormD<bits<6> opcode, string asmstr, list<dag> pattern> | 
|  | 83 | : InstAlpha<opcode, (ops target:$DISP), asmstr> { | 
|  | 84 | let Pattern = pattern; | 
|  | 85 |  | 
|  | 86 | bits<5> Ra; | 
| Andrew Lenharth | 5a99041 | 2005-10-22 22:06:58 +0000 | [diff] [blame] | 87 | bits<21> disp; | 
|  | 88 |  | 
|  | 89 | let Inst{25-21} = Ra; | 
|  | 90 | let Inst{20-0} = disp; | 
|  | 91 | } | 
| Andrew Lenharth | 6bec63a | 2006-01-01 22:16:14 +0000 | [diff] [blame] | 92 | let isBranch = 1, isTerminator = 1 in | 
| Andrew Lenharth | 0a01374 | 2006-01-26 03:24:15 +0000 | [diff] [blame] | 93 | class BForm<bits<6> opcode, string asmstr, list<dag> pattern> | 
| Andrew Lenharth | 6bec63a | 2006-01-01 22:16:14 +0000 | [diff] [blame] | 94 | : InstAlpha<opcode, (ops GPRC:$RA, target:$DISP), asmstr> { | 
|  | 95 | let Pattern = pattern; | 
|  | 96 |  | 
|  | 97 | bits<5> Ra; | 
|  | 98 | bits<21> disp; | 
|  | 99 |  | 
|  | 100 | let Inst{25-21} = Ra; | 
|  | 101 | let Inst{20-0} = disp; | 
|  | 102 | } | 
| Andrew Lenharth | 02daecc | 2005-07-22 20:50:29 +0000 | [diff] [blame] | 103 |  | 
|  | 104 | let isBranch = 1, isTerminator = 1 in | 
| Andrew Lenharth | 6bec63a | 2006-01-01 22:16:14 +0000 | [diff] [blame] | 105 | class FBForm<bits<6> opcode, string asmstr, list<dag> pattern> | 
|  | 106 | : InstAlpha<opcode, (ops F8RC:$RA, target:$DISP), asmstr> { | 
|  | 107 | let Pattern = pattern; | 
|  | 108 |  | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 109 | bits<5> Ra; | 
|  | 110 | bits<21> disp; | 
|  | 111 |  | 
|  | 112 | let Inst{25-21} = Ra; | 
|  | 113 | let Inst{20-0} = disp; | 
|  | 114 | } | 
|  | 115 |  | 
|  | 116 | //3.3.3 | 
| Andrew Lenharth | 7b69867 | 2005-10-20 00:28:31 +0000 | [diff] [blame] | 117 | class OForm<bits<6> opcode, bits<7> fun, string asmstr, list<dag> pattern> | 
| Andrew Lenharth | 02daecc | 2005-07-22 20:50:29 +0000 | [diff] [blame] | 118 | : InstAlpha<opcode, (ops GPRC:$RC, GPRC:$RA, GPRC:$RB), asmstr> { | 
| Andrew Lenharth | 7b69867 | 2005-10-20 00:28:31 +0000 | [diff] [blame] | 119 | let Pattern = pattern; | 
|  | 120 |  | 
| Andrew Lenharth | 02daecc | 2005-07-22 20:50:29 +0000 | [diff] [blame] | 121 | bits<5> Rc; | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 122 | bits<5> Ra; | 
|  | 123 | bits<5> Rb; | 
| Andrew Lenharth | 02daecc | 2005-07-22 20:50:29 +0000 | [diff] [blame] | 124 | bits<7> Function = fun; | 
|  | 125 |  | 
|  | 126 | let Inst{25-21} = Ra; | 
|  | 127 | let Inst{20-16} = Rb; | 
|  | 128 | let Inst{15-13} = 0; | 
|  | 129 | let Inst{12} = 0; | 
|  | 130 | let Inst{11-5} = Function; | 
|  | 131 | let Inst{4-0} = Rc; | 
|  | 132 | } | 
|  | 133 |  | 
| Andrew Lenharth | a6a23b5 | 2005-10-20 23:58:36 +0000 | [diff] [blame] | 134 | class OForm2<bits<6> opcode, bits<7> fun, string asmstr, list<dag> pattern> | 
| Andrew Lenharth | d4c0ed7 | 2005-10-20 19:39:24 +0000 | [diff] [blame] | 135 | : InstAlpha<opcode, (ops GPRC:$RC, GPRC:$RB), asmstr> { | 
|  | 136 | let Pattern = pattern; | 
|  | 137 |  | 
|  | 138 | bits<5> Rc; | 
|  | 139 | bits<5> Rb; | 
|  | 140 | bits<7> Function = fun; | 
|  | 141 |  | 
| Andrew Lenharth | 5a99041 | 2005-10-22 22:06:58 +0000 | [diff] [blame] | 142 | let Inst{25-21} = 31; | 
| Andrew Lenharth | d4c0ed7 | 2005-10-20 19:39:24 +0000 | [diff] [blame] | 143 | let Inst{20-16} = Rb; | 
|  | 144 | let Inst{15-13} = 0; | 
|  | 145 | let Inst{12} = 0; | 
|  | 146 | let Inst{11-5} = Function; | 
|  | 147 | let Inst{4-0} = Rc; | 
|  | 148 | } | 
|  | 149 |  | 
| Andrew Lenharth | e788bbf | 2005-12-06 00:33:53 +0000 | [diff] [blame] | 150 | class OForm4<bits<6> opcode, bits<7> fun, string asmstr, list<dag> pattern> | 
| Andrew Lenharth | 3c7c4d7 | 2005-12-05 23:19:44 +0000 | [diff] [blame] | 151 | : InstAlphaAlt<opcode, asmstr> { | 
|  | 152 | let Pattern = pattern; | 
|  | 153 |  | 
|  | 154 | bits<5> Rc; | 
|  | 155 | bits<5> Rb; | 
|  | 156 | bits<5> Ra; | 
|  | 157 | bits<7> Function = fun; | 
|  | 158 |  | 
|  | 159 | let isTwoAddress = 1; | 
|  | 160 | let Inst{25-21} = Ra; | 
|  | 161 | let Inst{20-16} = Rb; | 
|  | 162 | let Inst{15-13} = 0; | 
|  | 163 | let Inst{12} = 0; | 
|  | 164 | let Inst{11-5} = Function; | 
|  | 165 | let Inst{4-0} = Rc; | 
|  | 166 | } | 
|  | 167 |  | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 168 |  | 
| Andrew Lenharth | 7b69867 | 2005-10-20 00:28:31 +0000 | [diff] [blame] | 169 | class OFormL<bits<6> opcode, bits<7> fun, string asmstr, list<dag> pattern> | 
| Andrew Lenharth | 02daecc | 2005-07-22 20:50:29 +0000 | [diff] [blame] | 170 | : InstAlpha<opcode, (ops GPRC:$RC, GPRC:$RA, u8imm:$L), asmstr> { | 
| Andrew Lenharth | 7b69867 | 2005-10-20 00:28:31 +0000 | [diff] [blame] | 171 | let Pattern = pattern; | 
|  | 172 |  | 
| Andrew Lenharth | 02daecc | 2005-07-22 20:50:29 +0000 | [diff] [blame] | 173 | bits<5> Rc; | 
|  | 174 | bits<5> Ra; | 
|  | 175 | bits<8> LIT; | 
|  | 176 | bits<7> Function = fun; | 
|  | 177 |  | 
|  | 178 | let Inst{25-21} = Ra; | 
|  | 179 | let Inst{20-13} = LIT; | 
|  | 180 | let Inst{12} = 1; | 
|  | 181 | let Inst{11-5} = Function; | 
|  | 182 | let Inst{4-0} = Rc; | 
|  | 183 | } | 
|  | 184 |  | 
| Andrew Lenharth | a6a23b5 | 2005-10-20 23:58:36 +0000 | [diff] [blame] | 185 | class OForm4L<bits<6> opcode, bits<7> fun, string asmstr> | 
|  | 186 | : InstAlpha<opcode, (ops GPRC:$RDEST, GPRC:$RSRC2, u8imm:$L, GPRC:$RCOND), asmstr> { | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 187 | bits<5> Rc; | 
| Andrew Lenharth | a6a23b5 | 2005-10-20 23:58:36 +0000 | [diff] [blame] | 188 | bits<8> LIT; | 
|  | 189 | bits<5> Ra; | 
|  | 190 | bits<7> Function = fun; | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 191 |  | 
| Andrew Lenharth | a6a23b5 | 2005-10-20 23:58:36 +0000 | [diff] [blame] | 192 | let isTwoAddress = 1; | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 193 | let Inst{25-21} = Ra; | 
|  | 194 | let Inst{20-13} = LIT; | 
|  | 195 | let Inst{12} = 1; | 
|  | 196 | let Inst{11-5} = Function; | 
|  | 197 | let Inst{4-0} = Rc; | 
|  | 198 | } | 
|  | 199 |  | 
|  | 200 | //3.3.4 | 
| Andrew Lenharth | 97a7fcf | 2005-11-09 19:17:08 +0000 | [diff] [blame] | 201 | class FPForm<bits<6> opcode, bits<11> fun, string asmstr, list<dag> pattern> | 
|  | 202 | : InstAlphaAlt<opcode, asmstr> { | 
|  | 203 | let Pattern = pattern; | 
|  | 204 |  | 
| Andrew Lenharth | 1ec48e8 | 2005-07-28 18:14:47 +0000 | [diff] [blame] | 205 | bits<5> Fc; | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 206 | bits<5> Fa; | 
|  | 207 | bits<5> Fb; | 
| Andrew Lenharth | 5ae5f81 | 2005-01-26 21:54:09 +0000 | [diff] [blame] | 208 | bits<11> Function = fun; | 
| Andrew Lenharth | 1ec48e8 | 2005-07-28 18:14:47 +0000 | [diff] [blame] | 209 |  | 
|  | 210 | let Inst{25-21} = Fa; | 
|  | 211 | let Inst{20-16} = Fb; | 
|  | 212 | let Inst{15-5} = Function; | 
|  | 213 | let Inst{4-0} = Fc; | 
|  | 214 | } | 
|  | 215 |  | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 216 | //3.3.5 | 
|  | 217 | class PALForm<bits<6> opcode, dag OL, string asmstr> : InstAlpha<opcode, OL, asmstr> { | 
|  | 218 | bits<26> Function; | 
|  | 219 |  | 
|  | 220 | let Inst{25-0} = Function; | 
|  | 221 | } | 
|  | 222 |  | 
|  | 223 |  | 
|  | 224 | // Pseudo instructions. | 
| Andrew Lenharth | 0294e33 | 2005-11-22 04:20:06 +0000 | [diff] [blame] | 225 | class PseudoInstAlpha<dag OL, string nm, list<dag> pattern> : InstAlpha<0, OL, nm>  { | 
|  | 226 | let Pattern = pattern; | 
|  | 227 |  | 
| Andrew Lenharth | a1b5ca2 | 2005-01-22 23:41:55 +0000 | [diff] [blame] | 228 | } |