Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 1 | //===- SystemZInstrFP.td - SystemZ FP 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 SystemZ (binary) floating point instructions in |
| 11 | // TableGen format. |
| 12 | // |
| 13 | //===----------------------------------------------------------------------===// |
| 14 | |
| 15 | // FIXME: multiclassify! |
| 16 | |
Anton Korobeynikov | ef36562 | 2009-07-16 14:22:15 +0000 | [diff] [blame^] | 17 | let usesCustomDAGSchedInserter = 1 in { |
| 18 | def SelectF32 : Pseudo<(outs FP32:$dst), (ins FP32:$src1, FP32:$src2, i8imm:$cc), |
| 19 | "# SelectF32 PSEUDO", |
| 20 | [(set FP32:$dst, |
| 21 | (SystemZselect FP32:$src1, FP32:$src2, imm:$cc))]>; |
| 22 | def SelectF64 : Pseudo<(outs FP64:$dst), (ins FP64:$src1, FP64:$src2, i8imm:$cc), |
| 23 | "# SelectF64 PSEUDO", |
| 24 | [(set FP64:$dst, |
| 25 | (SystemZselect FP64:$src1, FP64:$src2, imm:$cc))]>; |
| 26 | } |
| 27 | |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 28 | //===----------------------------------------------------------------------===// |
| 29 | // Move Instructions |
| 30 | |
| 31 | let neverHasSideEffects = 1 in { |
| 32 | def FMOV32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src), |
| 33 | "ler\t{$dst, $src}", |
| 34 | []>; |
| 35 | def FMOV64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src), |
| 36 | "ldr\t{$dst, $src}", |
| 37 | []>; |
| 38 | } |
| 39 | |
| 40 | let canFoldAsLoad = 1, isReMaterializable = 1, mayHaveSideEffects = 1 in { |
| 41 | def FMOV32rm : Pseudo<(outs FP32:$dst), (ins rriaddr12:$src), |
| 42 | "le\t{$dst, $src}", |
| 43 | [(set FP32:$dst, (load rriaddr12:$src))]>; |
| 44 | def FMOV32rmy : Pseudo<(outs FP32:$dst), (ins rriaddr:$src), |
| 45 | "ley\t{$dst, $src}", |
| 46 | [(set FP32:$dst, (load rriaddr:$src))]>; |
| 47 | def FMOV64rm : Pseudo<(outs FP64:$dst), (ins rriaddr12:$src), |
| 48 | "ld\t{$dst, $src}", |
| 49 | [(set FP64:$dst, (load rriaddr12:$src))]>; |
| 50 | def FMOV64rmy : Pseudo<(outs FP64:$dst), (ins rriaddr:$src), |
| 51 | "ldy\t{$dst, $src}", |
| 52 | [(set FP64:$dst, (load rriaddr:$src))]>; |
| 53 | } |
| 54 | |
| 55 | def FMOV32mr : Pseudo<(outs), (ins rriaddr12:$dst, FP32:$src), |
| 56 | "ste\t{$src, $dst}", |
| 57 | [(store FP32:$src, rriaddr12:$dst)]>; |
| 58 | def FMOV32mry : Pseudo<(outs), (ins rriaddr:$dst, FP32:$src), |
| 59 | "stey\t{$src, $dst}", |
| 60 | [(store FP32:$src, rriaddr:$dst)]>; |
| 61 | def FMOV64mr : Pseudo<(outs), (ins rriaddr12:$dst, FP64:$src), |
| 62 | "std\t{$src, $dst}", |
| 63 | [(store FP64:$src, rriaddr12:$dst)]>; |
| 64 | def FMOV64mry : Pseudo<(outs), (ins rriaddr:$dst, FP64:$src), |
| 65 | "stdy\t{$src, $dst}", |
| 66 | [(store FP64:$src, rriaddr:$dst)]>; |
| 67 | |
| 68 | //===----------------------------------------------------------------------===// |
| 69 | // Arithmetic Instructions |
| 70 | |
Anton Korobeynikov | 99d2590 | 2009-07-16 14:21:12 +0000 | [diff] [blame] | 71 | |
| 72 | |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 73 | let isTwoAddress = 1 in { |
Anton Korobeynikov | 99d2590 | 2009-07-16 14:21:12 +0000 | [diff] [blame] | 74 | def FNEG32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src), |
| 75 | "lcebr\t{$dst}", |
| 76 | [(set FP32:$dst, (fneg FP32:$src))]>; |
| 77 | def FNEG64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src), |
| 78 | "lcdbr\t{$dst}", |
| 79 | [(set FP64:$dst, (fneg FP64:$src))]>; |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 80 | |
Anton Korobeynikov | 7af6514 | 2009-07-16 14:21:27 +0000 | [diff] [blame] | 81 | // FIXME: Add peephole for fneg(fabs) => load negative |
| 82 | |
| 83 | def FABS32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src), |
| 84 | "lpebr\t{$dst}", |
| 85 | [(set FP32:$dst, (fabs FP32:$src))]>; |
| 86 | def FABS64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src), |
| 87 | "lpdbr\t{$dst}", |
| 88 | [(set FP64:$dst, (fabs FP64:$src))]>; |
| 89 | |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 90 | let isCommutable = 1 in { // X = ADD Y, Z == X = ADD Z, Y |
| 91 | def FADD32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src1, FP32:$src2), |
| 92 | "aebr\t{$dst, $src2}", |
| 93 | [(set FP32:$dst, (fadd FP32:$src1, FP32:$src2))]>; |
| 94 | def FADD64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src1, FP64:$src2), |
| 95 | "adbr\t{$dst, $src2}", |
| 96 | [(set FP64:$dst, (fadd FP64:$src1, FP64:$src2))]>; |
| 97 | } |
| 98 | |
| 99 | def FADD32rm : Pseudo<(outs FP32:$dst), (ins FP32:$src1, rriaddr:$src2), |
| 100 | "aeb\t{$dst, $src2}", |
| 101 | [(set FP32:$dst, (fadd FP32:$src1, (load rriaddr:$src2)))]>; |
| 102 | def FADD64rm : Pseudo<(outs FP64:$dst), (ins FP64:$src1, rriaddr:$src2), |
| 103 | "adb\t{$dst, $src2}", |
| 104 | [(set FP64:$dst, (fadd FP64:$src1, (load rriaddr:$src2)))]>; |
| 105 | |
| 106 | def FSUB32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src1, FP32:$src2), |
| 107 | "sebr\t{$dst, $src2}", |
| 108 | [(set FP32:$dst, (fsub FP32:$src1, FP32:$src2))]>; |
| 109 | def FSUB64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src1, FP64:$src2), |
| 110 | "sdbr\t{$dst, $src2}", |
| 111 | [(set FP64:$dst, (fsub FP64:$src1, FP64:$src2))]>; |
| 112 | |
| 113 | def FSUB32rm : Pseudo<(outs FP32:$dst), (ins FP32:$src1, rriaddr:$src2), |
| 114 | "seb\t{$dst, $src2}", |
| 115 | [(set FP32:$dst, (fsub FP32:$src1, (load rriaddr:$src2)))]>; |
| 116 | def FSUB64rm : Pseudo<(outs FP64:$dst), (ins FP64:$src1, rriaddr:$src2), |
| 117 | "sdb\t{$dst, $src2}", |
| 118 | [(set FP64:$dst, (fsub FP64:$src1, (load rriaddr:$src2)))]>; |
| 119 | |
| 120 | let isCommutable = 1 in { // X = MUL Y, Z == X = MUL Z, Y |
| 121 | def FMUL32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src1, FP32:$src2), |
| 122 | "meebr\t{$dst, $src2}", |
| 123 | [(set FP32:$dst, (fmul FP32:$src1, FP32:$src2))]>; |
| 124 | def FMUL64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src1, FP64:$src2), |
| 125 | "mdbr\t{$dst, $src2}", |
| 126 | [(set FP64:$dst, (fmul FP64:$src1, FP64:$src2))]>; |
| 127 | } |
| 128 | |
| 129 | def FMUL32rm : Pseudo<(outs FP32:$dst), (ins FP32:$src1, rriaddr:$src2), |
| 130 | "meeb\t{$dst, $src2}", |
| 131 | [(set FP32:$dst, (fmul FP32:$src1, (load rriaddr:$src2)))]>; |
| 132 | def FMUL64rm : Pseudo<(outs FP64:$dst), (ins FP64:$src1, rriaddr:$src2), |
| 133 | "mdb\t{$dst, $src2}", |
| 134 | [(set FP64:$dst, (fmul FP64:$src1, (load rriaddr:$src2)))]>; |
| 135 | |
| 136 | def FDIV32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src1, FP32:$src2), |
| 137 | "debr\t{$dst, $src2}", |
| 138 | [(set FP32:$dst, (fdiv FP32:$src1, FP32:$src2))]>; |
| 139 | def FDIV64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src1, FP64:$src2), |
| 140 | "ddbr\t{$dst, $src2}", |
| 141 | [(set FP64:$dst, (fdiv FP64:$src1, FP64:$src2))]>; |
| 142 | |
| 143 | def FDIV32rm : Pseudo<(outs FP32:$dst), (ins FP32:$src1, rriaddr:$src2), |
| 144 | "deb\t{$dst, $src2}", |
| 145 | [(set FP32:$dst, (fdiv FP32:$src1, (load rriaddr:$src2)))]>; |
| 146 | def FDIV64rm : Pseudo<(outs FP64:$dst), (ins FP64:$src1, rriaddr:$src2), |
| 147 | "ddb\t{$dst, $src2}", |
| 148 | [(set FP64:$dst, (fdiv FP64:$src1, (load rriaddr:$src2)))]>; |
| 149 | |
| 150 | } // isTwoAddress = 1 |
| 151 | |
| 152 | def FROUND64r32 : Pseudo<(outs FP32:$dst), (ins FP64:$src), |
| 153 | "ledbr\t{$dst, $src}", |
| 154 | [(set FP32:$dst, (fround FP64:$src))]>; |
| 155 | |
| 156 | def FCONVFP32 : Pseudo<(outs FP32:$dst), (ins GR32:$src), |
| 157 | "cefbr\t{$dst, $src}", |
| 158 | [(set FP32:$dst, (sint_to_fp GR32:$src))]>; |
Anton Korobeynikov | 6030b05 | 2009-07-16 14:20:39 +0000 | [diff] [blame] | 159 | def FCONVFP32r64: Pseudo<(outs FP32:$dst), (ins GR64:$src), |
| 160 | "cegbr\t{$dst, $src}", |
| 161 | [(set FP32:$dst, (sint_to_fp GR64:$src))]>; |
| 162 | |
| 163 | def FCONVFP64r32: Pseudo<(outs FP64:$dst), (ins GR32:$src), |
| 164 | "cdfbr\t{$dst, $src}", |
| 165 | [(set FP64:$dst, (sint_to_fp GR32:$src))]>; |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 166 | def FCONVFP64 : Pseudo<(outs FP64:$dst), (ins GR64:$src), |
| 167 | "cdgbr\t{$dst, $src}", |
| 168 | [(set FP64:$dst, (sint_to_fp GR64:$src))]>; |
| 169 | |
Anton Korobeynikov | 01d5027 | 2009-07-16 14:21:57 +0000 | [diff] [blame] | 170 | def FCONVGR32 : Pseudo<(outs GR32:$dst), (ins FP32:$src), |
| 171 | "cfebr\t{$dst, $src}", |
| 172 | [(set GR32:$dst, (fp_to_sint FP32:$src))]>; |
| 173 | def FCONVGR32r64: Pseudo<(outs GR32:$dst), (ins FP64:$src), |
| 174 | "cgebr\t{$dst, $src}", |
| 175 | [(set GR32:$dst, (fp_to_sint FP64:$src))]>; |
| 176 | |
| 177 | def FCONVGR64r32: Pseudo<(outs GR64:$dst), (ins FP32:$src), |
| 178 | "cfdbr\t{$dst, $src}", |
| 179 | [(set GR64:$dst, (fp_to_sint FP32:$src))]>; |
| 180 | def FCONVGR64 : Pseudo<(outs GR64:$dst), (ins FP64:$src), |
| 181 | "cgdbr\t{$dst, $src}", |
| 182 | [(set GR64:$dst, (fp_to_sint FP64:$src))]>; |
| 183 | |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 184 | //===----------------------------------------------------------------------===// |
| 185 | // Test instructions (like AND but do not produce any result) |
| 186 | |
| 187 | // Integer comparisons |
| 188 | let Defs = [PSW] in { |
| 189 | def FCMP32rr : Pseudo<(outs), (ins FP32:$src1, FP32:$src2), |
| 190 | "cebr\t$src1, $src2", |
| 191 | [(SystemZcmp FP32:$src1, FP32:$src2), (implicit PSW)]>; |
| 192 | def FCMP64rr : Pseudo<(outs), (ins FP64:$src1, FP64:$src2), |
| 193 | "cdbr\t$src1, $src2", |
| 194 | [(SystemZcmp FP64:$src1, FP64:$src2), (implicit PSW)]>; |
| 195 | |
| 196 | def FCMP32rm : Pseudo<(outs), (ins FP32:$src1, rriaddr:$src2), |
| 197 | "ceb\t$src1, $src2", |
| 198 | [(SystemZcmp FP32:$src1, (load rriaddr:$src2)), |
| 199 | (implicit PSW)]>; |
| 200 | def FCMP64rm : Pseudo<(outs), (ins FP64:$src1, rriaddr:$src2), |
| 201 | "cdb\t$src1, $src2", |
| 202 | [(SystemZcmp FP64:$src1, (load rriaddr:$src2)), |
| 203 | (implicit PSW)]>; |
| 204 | } // Defs = [PSW] |