Anton Korobeynikov | 3717157 | 2009-05-03 12:57:15 +0000 | [diff] [blame] | 1 | //===- MSP430InstrInfo.td - MSP430 Instruction defs -----------*- tblgen-*-===// |
| 2 | // |
| 3 | // The LLVM Compiler Infrastructure |
| 4 | // |
| 5 | // This file is distributed under the University of Illinois Open Source |
| 6 | // License. See LICENSE.TXT for details. |
| 7 | // |
| 8 | //===----------------------------------------------------------------------===// |
| 9 | // |
| 10 | // This file describes the MSP430 instructions in TableGen format. |
| 11 | // |
| 12 | //===----------------------------------------------------------------------===// |
| 13 | |
| 14 | include "MSP430InstrFormats.td" |
| 15 | |
| 16 | //===----------------------------------------------------------------------===// |
| 17 | // Type Constraints. |
| 18 | //===----------------------------------------------------------------------===// |
| 19 | class SDTCisI8<int OpNum> : SDTCisVT<OpNum, i8>; |
| 20 | class SDTCisI16<int OpNum> : SDTCisVT<OpNum, i16>; |
| 21 | |
| 22 | //===----------------------------------------------------------------------===// |
| 23 | // Type Profiles. |
| 24 | //===----------------------------------------------------------------------===// |
| 25 | |
| 26 | //===----------------------------------------------------------------------===// |
| 27 | // MSP430 Specific Node Definitions. |
| 28 | //===----------------------------------------------------------------------===// |
Anton Korobeynikov | 184a31c | 2009-05-03 13:03:33 +0000 | [diff] [blame] | 29 | def MSP430retflag : SDNode<"MSP430ISD::RET_FLAG", SDTNone, |
Anton Korobeynikov | 725e2d0 | 2009-05-03 12:59:50 +0000 | [diff] [blame] | 30 | [SDNPHasChain, SDNPOptInFlag]>; |
Anton Korobeynikov | 3717157 | 2009-05-03 12:57:15 +0000 | [diff] [blame] | 31 | |
Anton Korobeynikov | 184a31c | 2009-05-03 13:03:33 +0000 | [diff] [blame] | 32 | def MSP430rra : SDNode<"MSP430ISD::RRA", SDTIntUnaryOp, []>; |
| 33 | |
Anton Korobeynikov | 3717157 | 2009-05-03 12:57:15 +0000 | [diff] [blame] | 34 | //===----------------------------------------------------------------------===// |
| 35 | // Pseudo Instructions |
| 36 | //===----------------------------------------------------------------------===// |
| 37 | |
Anton Korobeynikov | 5732297 | 2009-05-03 13:04:23 +0000 | [diff] [blame] | 38 | let neverHasSideEffects = 1 in |
Anton Korobeynikov | 3717157 | 2009-05-03 12:57:15 +0000 | [diff] [blame] | 39 | def NOP : Pseudo<(outs), (ins), "nop", []>; |
Anton Korobeynikov | 725e2d0 | 2009-05-03 12:59:50 +0000 | [diff] [blame] | 40 | |
| 41 | //===----------------------------------------------------------------------===// |
| 42 | // Real Instructions |
| 43 | //===----------------------------------------------------------------------===// |
| 44 | |
| 45 | // FIXME: Provide proper encoding! |
| 46 | let isReturn = 1, isTerminator = 1 in { |
Anton Korobeynikov | 184a31c | 2009-05-03 13:03:33 +0000 | [diff] [blame] | 47 | def RETI : Pseudo<(outs), (ins), "ret", [(MSP430retflag)]>; |
Anton Korobeynikov | f1fb8c7 | 2009-05-03 13:02:04 +0000 | [diff] [blame] | 48 | } |
| 49 | |
| 50 | //===----------------------------------------------------------------------===// |
| 51 | // Move Instructions |
| 52 | |
| 53 | // FIXME: Provide proper encoding! |
| 54 | let neverHasSideEffects = 1 in { |
| 55 | def MOV16rr : Pseudo<(outs GR16:$dst), (ins GR16:$src), |
| 56 | "mov.w\t{$src, $dst|$dst, $src}", |
| 57 | []>; |
| 58 | } |
| 59 | |
| 60 | // FIXME: Provide proper encoding! |
| 61 | let isReMaterializable = 1, isAsCheapAsAMove = 1 in { |
| 62 | def MOV16ri : Pseudo<(outs GR16:$dst), (ins i16imm:$src), |
| 63 | "mov.w\t{$src, $dst|$dst, $src}", |
| 64 | [(set GR16:$dst, imm:$src)]>; |
Anton Korobeynikov | 725e2d0 | 2009-05-03 12:59:50 +0000 | [diff] [blame] | 65 | } |
Anton Korobeynikov | 75b685d | 2009-05-03 13:02:39 +0000 | [diff] [blame] | 66 | |
| 67 | //===----------------------------------------------------------------------===// |
| 68 | // Arithmetic Instructions |
| 69 | |
Anton Korobeynikov | 70ecfb7 | 2009-05-03 13:04:06 +0000 | [diff] [blame] | 70 | let isTwoAddress = 1 in { |
Anton Korobeynikov | 75b685d | 2009-05-03 13:02:39 +0000 | [diff] [blame] | 71 | |
Anton Korobeynikov | c939140 | 2009-05-03 13:05:22 +0000 | [diff] [blame^] | 72 | let Defs = [SRW] in { |
Anton Korobeynikov | 70ecfb7 | 2009-05-03 13:04:06 +0000 | [diff] [blame] | 73 | |
| 74 | let isCommutable = 1 in { // X = ADD Y, Z == X = ADD Z, Y |
Anton Korobeynikov | 75b685d | 2009-05-03 13:02:39 +0000 | [diff] [blame] | 75 | // FIXME: Provide proper encoding! |
| 76 | def ADD16rr : Pseudo<(outs GR16:$dst), (ins GR16:$src1, GR16:$src2), |
| 77 | "add.w\t{$src2, $dst|$dst, $src2}", |
| 78 | [(set GR16:$dst, (add GR16:$src1, GR16:$src2)), |
Anton Korobeynikov | c939140 | 2009-05-03 13:05:22 +0000 | [diff] [blame^] | 79 | (implicit SRW)]>; |
Anton Korobeynikov | 51561ed | 2009-05-03 13:04:41 +0000 | [diff] [blame] | 80 | } |
| 81 | |
| 82 | def ADD16ri : Pseudo<(outs GR16:$dst), (ins GR16:$src1, i16imm:$src2), |
| 83 | "add.w\t{$src2, $dst|$dst, $src2}", |
| 84 | [(set GR16:$dst, (add GR16:$src1, imm:$src2)), |
Anton Korobeynikov | c939140 | 2009-05-03 13:05:22 +0000 | [diff] [blame^] | 85 | (implicit SRW)]>; |
Anton Korobeynikov | 70ecfb7 | 2009-05-03 13:04:06 +0000 | [diff] [blame] | 86 | |
Anton Korobeynikov | c939140 | 2009-05-03 13:05:22 +0000 | [diff] [blame^] | 87 | let Uses = [SRW] in { |
Anton Korobeynikov | 51561ed | 2009-05-03 13:04:41 +0000 | [diff] [blame] | 88 | |
| 89 | let isCommutable = 1 in { // X = ADDC Y, Z == X = ADDC Z, Y |
Anton Korobeynikov | 70ecfb7 | 2009-05-03 13:04:06 +0000 | [diff] [blame] | 90 | def ADC16rr : Pseudo<(outs GR16:$dst), (ins GR16:$src1, GR16:$src2), |
| 91 | "addc.w\t{$src2, $dst|$dst, $src2}", |
| 92 | [(set GR16:$dst, (adde GR16:$src1, GR16:$src2)), |
Anton Korobeynikov | c939140 | 2009-05-03 13:05:22 +0000 | [diff] [blame^] | 93 | (implicit SRW)]>; |
Anton Korobeynikov | 51561ed | 2009-05-03 13:04:41 +0000 | [diff] [blame] | 94 | } // isCommutable |
| 95 | |
| 96 | def ADC16ri : Pseudo<(outs GR16:$dst), (ins GR16:$src1, i16imm:$src2), |
| 97 | "addc.w\t{$src2, $dst|$dst, $src2}", |
| 98 | [(set GR16:$dst, (adde GR16:$src1, imm:$src2)), |
Anton Korobeynikov | c939140 | 2009-05-03 13:05:22 +0000 | [diff] [blame^] | 99 | (implicit SRW)]>; |
Anton Korobeynikov | 70ecfb7 | 2009-05-03 13:04:06 +0000 | [diff] [blame] | 100 | } |
| 101 | |
| 102 | let isCommutable = 1 in { // X = AND Y, Z == X = AND Z, Y |
| 103 | def AND16rr : Pseudo<(outs GR16:$dst), (ins GR16:$src1, GR16:$src2), |
| 104 | "and.w\t{$src2, $dst|$dst, $src2}", |
| 105 | [(set GR16:$dst, (and GR16:$src1, GR16:$src2)), |
Anton Korobeynikov | c939140 | 2009-05-03 13:05:22 +0000 | [diff] [blame^] | 106 | (implicit SRW)]>; |
Anton Korobeynikov | 70ecfb7 | 2009-05-03 13:04:06 +0000 | [diff] [blame] | 107 | } |
| 108 | |
Anton Korobeynikov | 51561ed | 2009-05-03 13:04:41 +0000 | [diff] [blame] | 109 | def AND16ri : Pseudo<(outs GR16:$dst), (ins GR16:$src1, i16imm:$src2), |
| 110 | "and.w\t{$src2, $dst|$dst, $src2}", |
| 111 | [(set GR16:$dst, (and GR16:$src1, imm:$src2)), |
Anton Korobeynikov | c939140 | 2009-05-03 13:05:22 +0000 | [diff] [blame^] | 112 | (implicit SRW)]>; |
Anton Korobeynikov | 51561ed | 2009-05-03 13:04:41 +0000 | [diff] [blame] | 113 | |
| 114 | let isCommutable = 1 in { // X = XOR Y, Z == X = XOR Z, Y |
Anton Korobeynikov | 70ecfb7 | 2009-05-03 13:04:06 +0000 | [diff] [blame] | 115 | def XOR16rr : Pseudo<(outs GR16:$dst), (ins GR16:$src1, GR16:$src2), |
| 116 | "xor.w\t{$src2, $dst|$dst, $src2}", |
| 117 | [(set GR16:$dst, (xor GR16:$src1, GR16:$src2)), |
Anton Korobeynikov | c939140 | 2009-05-03 13:05:22 +0000 | [diff] [blame^] | 118 | (implicit SRW)]>; |
Anton Korobeynikov | 70ecfb7 | 2009-05-03 13:04:06 +0000 | [diff] [blame] | 119 | } |
| 120 | |
Anton Korobeynikov | 51561ed | 2009-05-03 13:04:41 +0000 | [diff] [blame] | 121 | def XOR16ri : Pseudo<(outs GR16:$dst), (ins GR16:$src1, i16imm:$src2), |
| 122 | "xor.w\t{$src2, $dst|$dst, $src2}", |
| 123 | [(set GR16:$dst, (xor GR16:$src1, imm:$src2)), |
Anton Korobeynikov | c939140 | 2009-05-03 13:05:22 +0000 | [diff] [blame^] | 124 | (implicit SRW)]>; |
Anton Korobeynikov | 51561ed | 2009-05-03 13:04:41 +0000 | [diff] [blame] | 125 | |
Anton Korobeynikov | 70ecfb7 | 2009-05-03 13:04:06 +0000 | [diff] [blame] | 126 | |
| 127 | def SUB16rr : Pseudo<(outs GR16:$dst), (ins GR16:$src1, GR16:$src2), |
| 128 | "sub.w\t{$src2, $dst|$dst, $src2}", |
| 129 | [(set GR16:$dst, (sub GR16:$src1, GR16:$src2)), |
Anton Korobeynikov | c939140 | 2009-05-03 13:05:22 +0000 | [diff] [blame^] | 130 | (implicit SRW)]>; |
Anton Korobeynikov | 70ecfb7 | 2009-05-03 13:04:06 +0000 | [diff] [blame] | 131 | |
Anton Korobeynikov | 51561ed | 2009-05-03 13:04:41 +0000 | [diff] [blame] | 132 | def SUB16ri : Pseudo<(outs GR16:$dst), (ins GR16:$src1, i16imm:$src2), |
| 133 | "sub.w\t{$src2, $dst|$dst, $src2}", |
| 134 | [(set GR16:$dst, (sub GR16:$src1, imm:$src2)), |
Anton Korobeynikov | c939140 | 2009-05-03 13:05:22 +0000 | [diff] [blame^] | 135 | (implicit SRW)]>; |
Anton Korobeynikov | 51561ed | 2009-05-03 13:04:41 +0000 | [diff] [blame] | 136 | |
Anton Korobeynikov | c939140 | 2009-05-03 13:05:22 +0000 | [diff] [blame^] | 137 | let Uses = [SRW] in { |
Anton Korobeynikov | 70ecfb7 | 2009-05-03 13:04:06 +0000 | [diff] [blame] | 138 | def SBC16rr : Pseudo<(outs GR16:$dst), (ins GR16:$src1, GR16:$src2), |
| 139 | "subc.w\t{$src2, $dst|$dst, $src2}", |
| 140 | [(set GR16:$dst, (sube GR16:$src1, GR16:$src2)), |
Anton Korobeynikov | c939140 | 2009-05-03 13:05:22 +0000 | [diff] [blame^] | 141 | (implicit SRW)]>; |
Anton Korobeynikov | 51561ed | 2009-05-03 13:04:41 +0000 | [diff] [blame] | 142 | |
| 143 | def SBC16ri : Pseudo<(outs GR16:$dst), (ins GR16:$src1, i16imm:$src2), |
| 144 | "subc.w\t{$src2, $dst|$dst, $src2}", |
| 145 | [(set GR16:$dst, (sube GR16:$src1, imm:$src2)), |
Anton Korobeynikov | c939140 | 2009-05-03 13:05:22 +0000 | [diff] [blame^] | 146 | (implicit SRW)]>; |
Anton Korobeynikov | 75b685d | 2009-05-03 13:02:39 +0000 | [diff] [blame] | 147 | } |
Anton Korobeynikov | 184a31c | 2009-05-03 13:03:33 +0000 | [diff] [blame] | 148 | |
| 149 | // FIXME: Provide proper encoding! |
Anton Korobeynikov | 184a31c | 2009-05-03 13:03:33 +0000 | [diff] [blame] | 150 | def SAR16r1 : Pseudo<(outs GR16:$dst), (ins GR16:$src), |
| 151 | "rra.w\t$dst", |
| 152 | [(set GR16:$dst, (MSP430rra GR16:$src)), |
Anton Korobeynikov | c939140 | 2009-05-03 13:05:22 +0000 | [diff] [blame^] | 153 | (implicit SRW)]>; |
| 154 | |
| 155 | def SEXT16r : Pseudo<(outs GR16:$dst), (ins GR16:$src), |
| 156 | "sxt\t$dst", |
| 157 | [(set GR16:$dst, (sext_inreg GR16:$src, i8)), |
| 158 | (implicit SRW)]>; |
| 159 | |
| 160 | } // Defs = [SRW] |
Anton Korobeynikov | f6ea9e9 | 2009-05-03 13:05:00 +0000 | [diff] [blame] | 161 | |
| 162 | let isCommutable = 1 in { // X = OR Y, Z == X = OR Z, Y |
| 163 | def OR16rr : Pseudo<(outs GR16:$dst), (ins GR16:$src1, GR16:$src2), |
| 164 | "bis.w\t{$src2, $dst|$dst, $src2}", |
| 165 | [(set GR16:$dst, (or GR16:$src1, GR16:$src2))]>; |
| 166 | } |
| 167 | |
| 168 | def OR16ri : Pseudo<(outs GR16:$dst), (ins GR16:$src1, i16imm:$src2), |
| 169 | "bis.w\t{$src2, $dst|$dst, $src2}", |
| 170 | [(set GR16:$dst, (or GR16:$src1, imm:$src2))]>; |
| 171 | |
Anton Korobeynikov | 70ecfb7 | 2009-05-03 13:04:06 +0000 | [diff] [blame] | 172 | } // isTwoAddress = 1 |