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 | d74629f | 2009-07-16 14:24:16 +0000 | [diff] [blame] | 17 | //===----------------------------------------------------------------------===// |
| 18 | // FP Pattern fragments |
| 19 | |
| 20 | def fpimm0 : PatLeaf<(fpimm), [{ |
| 21 | return N->isExactlyValue(+0.0); |
| 22 | }]>; |
| 23 | |
| 24 | def fpimmneg0 : PatLeaf<(fpimm), [{ |
| 25 | return N->isExactlyValue(-0.0); |
| 26 | }]>; |
| 27 | |
Dan Gohman | fd3ac55 | 2009-10-28 00:55:57 +0000 | [diff] [blame^] | 28 | let Uses = [PSW], usesCustomDAGSchedInserter = 1 in { |
Anton Korobeynikov | ef36562 | 2009-07-16 14:22:15 +0000 | [diff] [blame] | 29 | def SelectF32 : Pseudo<(outs FP32:$dst), (ins FP32:$src1, FP32:$src2, i8imm:$cc), |
| 30 | "# SelectF32 PSEUDO", |
| 31 | [(set FP32:$dst, |
Dan Gohman | fd3ac55 | 2009-10-28 00:55:57 +0000 | [diff] [blame^] | 32 | (SystemZselect FP32:$src1, FP32:$src2, imm:$cc, PSW))]>; |
Anton Korobeynikov | ef36562 | 2009-07-16 14:22:15 +0000 | [diff] [blame] | 33 | def SelectF64 : Pseudo<(outs FP64:$dst), (ins FP64:$src1, FP64:$src2, i8imm:$cc), |
| 34 | "# SelectF64 PSEUDO", |
| 35 | [(set FP64:$dst, |
Dan Gohman | fd3ac55 | 2009-10-28 00:55:57 +0000 | [diff] [blame^] | 36 | (SystemZselect FP64:$src1, FP64:$src2, imm:$cc, PSW))]>; |
Anton Korobeynikov | ef36562 | 2009-07-16 14:22:15 +0000 | [diff] [blame] | 37 | } |
| 38 | |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 39 | //===----------------------------------------------------------------------===// |
| 40 | // Move Instructions |
| 41 | |
Anton Korobeynikov | d74629f | 2009-07-16 14:24:16 +0000 | [diff] [blame] | 42 | // Floating point constant loads. |
| 43 | let isReMaterializable = 1, isAsCheapAsAMove = 1 in { |
| 44 | def LD_Fp032 : Pseudo<(outs FP32:$dst), (ins), |
| 45 | "lzer\t{$dst}", |
| 46 | [(set FP32:$dst, fpimm0)]>; |
| 47 | def LD_Fp064 : Pseudo<(outs FP64:$dst), (ins), |
| 48 | "lzdr\t{$dst}", |
| 49 | [(set FP64:$dst, fpimm0)]>; |
| 50 | } |
| 51 | |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 52 | let neverHasSideEffects = 1 in { |
| 53 | def FMOV32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src), |
| 54 | "ler\t{$dst, $src}", |
| 55 | []>; |
| 56 | def FMOV64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src), |
| 57 | "ldr\t{$dst, $src}", |
| 58 | []>; |
| 59 | } |
| 60 | |
| 61 | let canFoldAsLoad = 1, isReMaterializable = 1, mayHaveSideEffects = 1 in { |
| 62 | def FMOV32rm : Pseudo<(outs FP32:$dst), (ins rriaddr12:$src), |
| 63 | "le\t{$dst, $src}", |
| 64 | [(set FP32:$dst, (load rriaddr12:$src))]>; |
| 65 | def FMOV32rmy : Pseudo<(outs FP32:$dst), (ins rriaddr:$src), |
| 66 | "ley\t{$dst, $src}", |
| 67 | [(set FP32:$dst, (load rriaddr:$src))]>; |
| 68 | def FMOV64rm : Pseudo<(outs FP64:$dst), (ins rriaddr12:$src), |
| 69 | "ld\t{$dst, $src}", |
| 70 | [(set FP64:$dst, (load rriaddr12:$src))]>; |
| 71 | def FMOV64rmy : Pseudo<(outs FP64:$dst), (ins rriaddr:$src), |
| 72 | "ldy\t{$dst, $src}", |
| 73 | [(set FP64:$dst, (load rriaddr:$src))]>; |
| 74 | } |
| 75 | |
| 76 | def FMOV32mr : Pseudo<(outs), (ins rriaddr12:$dst, FP32:$src), |
| 77 | "ste\t{$src, $dst}", |
| 78 | [(store FP32:$src, rriaddr12:$dst)]>; |
| 79 | def FMOV32mry : Pseudo<(outs), (ins rriaddr:$dst, FP32:$src), |
| 80 | "stey\t{$src, $dst}", |
| 81 | [(store FP32:$src, rriaddr:$dst)]>; |
| 82 | def FMOV64mr : Pseudo<(outs), (ins rriaddr12:$dst, FP64:$src), |
| 83 | "std\t{$src, $dst}", |
| 84 | [(store FP64:$src, rriaddr12:$dst)]>; |
| 85 | def FMOV64mry : Pseudo<(outs), (ins rriaddr:$dst, FP64:$src), |
| 86 | "stdy\t{$src, $dst}", |
| 87 | [(store FP64:$src, rriaddr:$dst)]>; |
| 88 | |
Anton Korobeynikov | af04869 | 2009-08-21 20:02:37 +0000 | [diff] [blame] | 89 | def FCOPYSIGN32 : Pseudo<(outs FP32:$dst), (ins FP32:$src1, FP32:$src2), |
| 90 | "cpsdr\t{$dst, $src2, $src1}", |
| 91 | [(set FP32:$dst, (fcopysign FP32:$src1, FP32:$src2))]>; |
| 92 | def FCOPYSIGN64 : Pseudo<(outs FP64:$dst), (ins FP64:$src1, FP64:$src2), |
| 93 | "cpsdr\t{$dst, $src2, $src1}", |
| 94 | [(set FP64:$dst, (fcopysign FP64:$src1, FP64:$src2))]>; |
| 95 | |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 96 | //===----------------------------------------------------------------------===// |
| 97 | // Arithmetic Instructions |
| 98 | |
Anton Korobeynikov | 99d2590 | 2009-07-16 14:21:12 +0000 | [diff] [blame] | 99 | |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 100 | let Defs = [PSW] in { |
Anton Korobeynikov | 99d2590 | 2009-07-16 14:21:12 +0000 | [diff] [blame] | 101 | def FNEG32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src), |
Anton Korobeynikov | 705c80a | 2009-07-16 14:23:30 +0000 | [diff] [blame] | 102 | "lcebr\t{$dst, $src}", |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 103 | [(set FP32:$dst, (fneg FP32:$src)), |
| 104 | (implicit PSW)]>; |
Anton Korobeynikov | 99d2590 | 2009-07-16 14:21:12 +0000 | [diff] [blame] | 105 | def FNEG64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src), |
Anton Korobeynikov | 705c80a | 2009-07-16 14:23:30 +0000 | [diff] [blame] | 106 | "lcdbr\t{$dst, $src}", |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 107 | [(set FP64:$dst, (fneg FP64:$src)), |
| 108 | (implicit PSW)]>; |
Anton Korobeynikov | 7af6514 | 2009-07-16 14:21:27 +0000 | [diff] [blame] | 109 | |
| 110 | def FABS32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src), |
Anton Korobeynikov | 797c38e | 2009-07-16 14:24:01 +0000 | [diff] [blame] | 111 | "lpebr\t{$dst, $src}", |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 112 | [(set FP32:$dst, (fabs FP32:$src)), |
| 113 | (implicit PSW)]>; |
Anton Korobeynikov | 7af6514 | 2009-07-16 14:21:27 +0000 | [diff] [blame] | 114 | def FABS64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src), |
Anton Korobeynikov | 797c38e | 2009-07-16 14:24:01 +0000 | [diff] [blame] | 115 | "lpdbr\t{$dst, $src}", |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 116 | [(set FP64:$dst, (fabs FP64:$src)), |
| 117 | (implicit PSW)]>; |
Anton Korobeynikov | 7af6514 | 2009-07-16 14:21:27 +0000 | [diff] [blame] | 118 | |
Anton Korobeynikov | d7205d4 | 2009-07-16 14:23:44 +0000 | [diff] [blame] | 119 | def FNABS32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src), |
Anton Korobeynikov | 797c38e | 2009-07-16 14:24:01 +0000 | [diff] [blame] | 120 | "lnebr\t{$dst, $src}", |
Anton Korobeynikov | d7205d4 | 2009-07-16 14:23:44 +0000 | [diff] [blame] | 121 | [(set FP32:$dst, (fneg(fabs FP32:$src))), |
| 122 | (implicit PSW)]>; |
| 123 | def FNABS64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src), |
Anton Korobeynikov | 797c38e | 2009-07-16 14:24:01 +0000 | [diff] [blame] | 124 | "lndbr\t{$dst, $src}", |
Anton Korobeynikov | d7205d4 | 2009-07-16 14:23:44 +0000 | [diff] [blame] | 125 | [(set FP64:$dst, (fneg(fabs FP64:$src))), |
| 126 | (implicit PSW)]>; |
Anton Korobeynikov | 797c38e | 2009-07-16 14:24:01 +0000 | [diff] [blame] | 127 | } |
Anton Korobeynikov | d7205d4 | 2009-07-16 14:23:44 +0000 | [diff] [blame] | 128 | |
Anton Korobeynikov | 797c38e | 2009-07-16 14:24:01 +0000 | [diff] [blame] | 129 | let isTwoAddress = 1 in { |
| 130 | let Defs = [PSW] in { |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 131 | let isCommutable = 1 in { // X = ADD Y, Z == X = ADD Z, Y |
| 132 | def FADD32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src1, FP32:$src2), |
| 133 | "aebr\t{$dst, $src2}", |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 134 | [(set FP32:$dst, (fadd FP32:$src1, FP32:$src2)), |
| 135 | (implicit PSW)]>; |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 136 | def FADD64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src1, FP64:$src2), |
| 137 | "adbr\t{$dst, $src2}", |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 138 | [(set FP64:$dst, (fadd FP64:$src1, FP64:$src2)), |
| 139 | (implicit PSW)]>; |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 140 | } |
| 141 | |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 142 | def FADD32rm : Pseudo<(outs FP32:$dst), (ins FP32:$src1, rriaddr12:$src2), |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 143 | "aeb\t{$dst, $src2}", |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 144 | [(set FP32:$dst, (fadd FP32:$src1, (load rriaddr12:$src2))), |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 145 | (implicit PSW)]>; |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 146 | def FADD64rm : Pseudo<(outs FP64:$dst), (ins FP64:$src1, rriaddr12:$src2), |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 147 | "adb\t{$dst, $src2}", |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 148 | [(set FP64:$dst, (fadd FP64:$src1, (load rriaddr12:$src2))), |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 149 | (implicit PSW)]>; |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 150 | |
| 151 | def FSUB32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src1, FP32:$src2), |
| 152 | "sebr\t{$dst, $src2}", |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 153 | [(set FP32:$dst, (fsub FP32:$src1, FP32:$src2)), |
| 154 | (implicit PSW)]>; |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 155 | def FSUB64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src1, FP64:$src2), |
| 156 | "sdbr\t{$dst, $src2}", |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 157 | [(set FP64:$dst, (fsub FP64:$src1, FP64:$src2)), |
| 158 | (implicit PSW)]>; |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 159 | |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 160 | def FSUB32rm : Pseudo<(outs FP32:$dst), (ins FP32:$src1, rriaddr12:$src2), |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 161 | "seb\t{$dst, $src2}", |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 162 | [(set FP32:$dst, (fsub FP32:$src1, (load rriaddr12:$src2))), |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 163 | (implicit PSW)]>; |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 164 | def FSUB64rm : Pseudo<(outs FP64:$dst), (ins FP64:$src1, rriaddr12:$src2), |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 165 | "sdb\t{$dst, $src2}", |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 166 | [(set FP64:$dst, (fsub FP64:$src1, (load rriaddr12:$src2))), |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 167 | (implicit PSW)]>; |
| 168 | } // Defs = [PSW] |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 169 | |
| 170 | let isCommutable = 1 in { // X = MUL Y, Z == X = MUL Z, Y |
| 171 | def FMUL32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src1, FP32:$src2), |
| 172 | "meebr\t{$dst, $src2}", |
| 173 | [(set FP32:$dst, (fmul FP32:$src1, FP32:$src2))]>; |
| 174 | def FMUL64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src1, FP64:$src2), |
| 175 | "mdbr\t{$dst, $src2}", |
| 176 | [(set FP64:$dst, (fmul FP64:$src1, FP64:$src2))]>; |
| 177 | } |
| 178 | |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 179 | def FMUL32rm : Pseudo<(outs FP32:$dst), (ins FP32:$src1, rriaddr12:$src2), |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 180 | "meeb\t{$dst, $src2}", |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 181 | [(set FP32:$dst, (fmul FP32:$src1, (load rriaddr12:$src2)))]>; |
| 182 | def FMUL64rm : Pseudo<(outs FP64:$dst), (ins FP64:$src1, rriaddr12:$src2), |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 183 | "mdb\t{$dst, $src2}", |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 184 | [(set FP64:$dst, (fmul FP64:$src1, (load rriaddr12:$src2)))]>; |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 185 | |
Anton Korobeynikov | c2c2f78 | 2009-07-16 14:23:16 +0000 | [diff] [blame] | 186 | def FMADD32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src1, FP32:$src2, FP32:$src3), |
| 187 | "maebr\t{$dst, $src3, $src2}", |
| 188 | [(set FP32:$dst, (fadd (fmul FP32:$src2, FP32:$src3), |
| 189 | FP32:$src1))]>; |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 190 | def FMADD32rm : Pseudo<(outs FP32:$dst), (ins FP32:$src1, rriaddr12:$src2, FP32:$src3), |
Anton Korobeynikov | c2c2f78 | 2009-07-16 14:23:16 +0000 | [diff] [blame] | 191 | "maeb\t{$dst, $src3, $src2}", |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 192 | [(set FP32:$dst, (fadd (fmul (load rriaddr12:$src2), |
Anton Korobeynikov | c2c2f78 | 2009-07-16 14:23:16 +0000 | [diff] [blame] | 193 | FP32:$src3), |
| 194 | FP32:$src1))]>; |
| 195 | |
| 196 | def FMADD64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src1, FP64:$src2, FP64:$src3), |
| 197 | "madbr\t{$dst, $src3, $src2}", |
| 198 | [(set FP64:$dst, (fadd (fmul FP64:$src2, FP64:$src3), |
| 199 | FP64:$src1))]>; |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 200 | def FMADD64rm : Pseudo<(outs FP64:$dst), (ins FP64:$src1, rriaddr12:$src2, FP64:$src3), |
Anton Korobeynikov | c2c2f78 | 2009-07-16 14:23:16 +0000 | [diff] [blame] | 201 | "madb\t{$dst, $src3, $src2}", |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 202 | [(set FP64:$dst, (fadd (fmul (load rriaddr12:$src2), |
Anton Korobeynikov | c2c2f78 | 2009-07-16 14:23:16 +0000 | [diff] [blame] | 203 | FP64:$src3), |
| 204 | FP64:$src1))]>; |
| 205 | |
| 206 | def FMSUB32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src1, FP32:$src2, FP32:$src3), |
| 207 | "msebr\t{$dst, $src3, $src2}", |
| 208 | [(set FP32:$dst, (fsub (fmul FP32:$src2, FP32:$src3), |
| 209 | FP32:$src1))]>; |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 210 | def FMSUB32rm : Pseudo<(outs FP32:$dst), (ins FP32:$src1, rriaddr12:$src2, FP32:$src3), |
Anton Korobeynikov | c2c2f78 | 2009-07-16 14:23:16 +0000 | [diff] [blame] | 211 | "mseb\t{$dst, $src3, $src2}", |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 212 | [(set FP32:$dst, (fsub (fmul (load rriaddr12:$src2), |
Anton Korobeynikov | c2c2f78 | 2009-07-16 14:23:16 +0000 | [diff] [blame] | 213 | FP32:$src3), |
| 214 | FP32:$src1))]>; |
| 215 | |
| 216 | def FMSUB64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src1, FP64:$src2, FP64:$src3), |
| 217 | "msdbr\t{$dst, $src3, $src2}", |
| 218 | [(set FP64:$dst, (fsub (fmul FP64:$src2, FP64:$src3), |
| 219 | FP64:$src1))]>; |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 220 | def FMSUB64rm : Pseudo<(outs FP64:$dst), (ins FP64:$src1, rriaddr12:$src2, FP64:$src3), |
Anton Korobeynikov | c2c2f78 | 2009-07-16 14:23:16 +0000 | [diff] [blame] | 221 | "msdb\t{$dst, $src3, $src2}", |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 222 | [(set FP64:$dst, (fsub (fmul (load rriaddr12:$src2), |
Anton Korobeynikov | c2c2f78 | 2009-07-16 14:23:16 +0000 | [diff] [blame] | 223 | FP64:$src3), |
| 224 | FP64:$src1))]>; |
| 225 | |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 226 | def FDIV32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src1, FP32:$src2), |
| 227 | "debr\t{$dst, $src2}", |
| 228 | [(set FP32:$dst, (fdiv FP32:$src1, FP32:$src2))]>; |
| 229 | def FDIV64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src1, FP64:$src2), |
| 230 | "ddbr\t{$dst, $src2}", |
| 231 | [(set FP64:$dst, (fdiv FP64:$src1, FP64:$src2))]>; |
| 232 | |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 233 | def FDIV32rm : Pseudo<(outs FP32:$dst), (ins FP32:$src1, rriaddr12:$src2), |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 234 | "deb\t{$dst, $src2}", |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 235 | [(set FP32:$dst, (fdiv FP32:$src1, (load rriaddr12:$src2)))]>; |
| 236 | def FDIV64rm : Pseudo<(outs FP64:$dst), (ins FP64:$src1, rriaddr12:$src2), |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 237 | "ddb\t{$dst, $src2}", |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 238 | [(set FP64:$dst, (fdiv FP64:$src1, (load rriaddr12:$src2)))]>; |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 239 | |
| 240 | } // isTwoAddress = 1 |
| 241 | |
Anton Korobeynikov | d74629f | 2009-07-16 14:24:16 +0000 | [diff] [blame] | 242 | def FSQRT32rr : Pseudo<(outs FP32:$dst), (ins FP32:$src), |
| 243 | "sqebr\t{$dst, $src}", |
| 244 | [(set FP32:$dst, (fsqrt FP32:$src))]>; |
| 245 | def FSQRT64rr : Pseudo<(outs FP64:$dst), (ins FP64:$src), |
| 246 | "sqdbr\t{$dst, $src}", |
| 247 | [(set FP64:$dst, (fsqrt FP64:$src))]>; |
| 248 | |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 249 | def FSQRT32rm : Pseudo<(outs FP32:$dst), (ins rriaddr12:$src), |
Anton Korobeynikov | d74629f | 2009-07-16 14:24:16 +0000 | [diff] [blame] | 250 | "sqeb\t{$dst, $src}", |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 251 | [(set FP32:$dst, (fsqrt (load rriaddr12:$src)))]>; |
| 252 | def FSQRT64rm : Pseudo<(outs FP64:$dst), (ins rriaddr12:$src), |
Anton Korobeynikov | d74629f | 2009-07-16 14:24:16 +0000 | [diff] [blame] | 253 | "sqdb\t{$dst, $src}", |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 254 | [(set FP64:$dst, (fsqrt (load rriaddr12:$src)))]>; |
Anton Korobeynikov | d74629f | 2009-07-16 14:24:16 +0000 | [diff] [blame] | 255 | |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 256 | def FROUND64r32 : Pseudo<(outs FP32:$dst), (ins FP64:$src), |
| 257 | "ledbr\t{$dst, $src}", |
| 258 | [(set FP32:$dst, (fround FP64:$src))]>; |
| 259 | |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 260 | def FEXT32r64 : Pseudo<(outs FP64:$dst), (ins FP32:$src), |
| 261 | "ldebr\t{$dst, $src}", |
| 262 | [(set FP64:$dst, (fextend FP32:$src))]>; |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 263 | def FEXT32m64 : Pseudo<(outs FP64:$dst), (ins rriaddr12:$src), |
Anton Korobeynikov | 9c22446 | 2009-07-16 14:22:46 +0000 | [diff] [blame] | 264 | "ldeb\t{$dst, $src}", |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 265 | [(set FP64:$dst, (fextend (load rriaddr12:$src)))]>; |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 266 | |
| 267 | let Defs = [PSW] in { |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 268 | def FCONVFP32 : Pseudo<(outs FP32:$dst), (ins GR32:$src), |
| 269 | "cefbr\t{$dst, $src}", |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 270 | [(set FP32:$dst, (sint_to_fp GR32:$src)), |
| 271 | (implicit PSW)]>; |
Anton Korobeynikov | 6030b05 | 2009-07-16 14:20:39 +0000 | [diff] [blame] | 272 | def FCONVFP32r64: Pseudo<(outs FP32:$dst), (ins GR64:$src), |
| 273 | "cegbr\t{$dst, $src}", |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 274 | [(set FP32:$dst, (sint_to_fp GR64:$src)), |
| 275 | (implicit PSW)]>; |
Anton Korobeynikov | 6030b05 | 2009-07-16 14:20:39 +0000 | [diff] [blame] | 276 | |
| 277 | def FCONVFP64r32: Pseudo<(outs FP64:$dst), (ins GR32:$src), |
| 278 | "cdfbr\t{$dst, $src}", |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 279 | [(set FP64:$dst, (sint_to_fp GR32:$src)), |
| 280 | (implicit PSW)]>; |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 281 | def FCONVFP64 : Pseudo<(outs FP64:$dst), (ins GR64:$src), |
| 282 | "cdgbr\t{$dst, $src}", |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 283 | [(set FP64:$dst, (sint_to_fp GR64:$src)), |
| 284 | (implicit PSW)]>; |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 285 | |
Anton Korobeynikov | 01d5027 | 2009-07-16 14:21:57 +0000 | [diff] [blame] | 286 | def FCONVGR32 : Pseudo<(outs GR32:$dst), (ins FP32:$src), |
Anton Korobeynikov | 99efabf | 2009-07-16 14:25:12 +0000 | [diff] [blame] | 287 | "cfebr\t{$dst, 5, $src}", |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 288 | [(set GR32:$dst, (fp_to_sint FP32:$src)), |
| 289 | (implicit PSW)]>; |
Anton Korobeynikov | 01d5027 | 2009-07-16 14:21:57 +0000 | [diff] [blame] | 290 | def FCONVGR32r64: Pseudo<(outs GR32:$dst), (ins FP64:$src), |
Anton Korobeynikov | f58a99c | 2009-07-16 14:29:26 +0000 | [diff] [blame] | 291 | "cfdbr\t{$dst, 5, $src}", |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 292 | [(set GR32:$dst, (fp_to_sint FP64:$src)), |
| 293 | (implicit PSW)]>; |
Anton Korobeynikov | 01d5027 | 2009-07-16 14:21:57 +0000 | [diff] [blame] | 294 | |
| 295 | def FCONVGR64r32: Pseudo<(outs GR64:$dst), (ins FP32:$src), |
Anton Korobeynikov | f58a99c | 2009-07-16 14:29:26 +0000 | [diff] [blame] | 296 | "cgebr\t{$dst, 5, $src}", |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 297 | [(set GR64:$dst, (fp_to_sint FP32:$src)), |
| 298 | (implicit PSW)]>; |
Anton Korobeynikov | 01d5027 | 2009-07-16 14:21:57 +0000 | [diff] [blame] | 299 | def FCONVGR64 : Pseudo<(outs GR64:$dst), (ins FP64:$src), |
Anton Korobeynikov | 99efabf | 2009-07-16 14:25:12 +0000 | [diff] [blame] | 300 | "cgdbr\t{$dst, 5, $src}", |
Anton Korobeynikov | 77374fb | 2009-07-16 14:22:30 +0000 | [diff] [blame] | 301 | [(set GR64:$dst, (fp_to_sint FP64:$src)), |
| 302 | (implicit PSW)]>; |
| 303 | } // Defs = [PSW] |
Anton Korobeynikov | 01d5027 | 2009-07-16 14:21:57 +0000 | [diff] [blame] | 304 | |
Anton Korobeynikov | b508aef | 2009-07-16 14:27:01 +0000 | [diff] [blame] | 305 | def FBCONVG64 : Pseudo<(outs GR64:$dst), (ins FP64:$src), |
| 306 | "lgdr\t{$dst, $src}", |
| 307 | [(set GR64:$dst, (bitconvert FP64:$src))]>; |
| 308 | def FBCONVF64 : Pseudo<(outs FP64:$dst), (ins GR64:$src), |
| 309 | "ldgr\t{$dst, $src}", |
| 310 | [(set FP64:$dst, (bitconvert GR64:$src))]>; |
| 311 | |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 312 | //===----------------------------------------------------------------------===// |
| 313 | // Test instructions (like AND but do not produce any result) |
| 314 | |
| 315 | // Integer comparisons |
| 316 | let Defs = [PSW] in { |
| 317 | def FCMP32rr : Pseudo<(outs), (ins FP32:$src1, FP32:$src2), |
| 318 | "cebr\t$src1, $src2", |
| 319 | [(SystemZcmp FP32:$src1, FP32:$src2), (implicit PSW)]>; |
| 320 | def FCMP64rr : Pseudo<(outs), (ins FP64:$src1, FP64:$src2), |
| 321 | "cdbr\t$src1, $src2", |
| 322 | [(SystemZcmp FP64:$src1, FP64:$src2), (implicit PSW)]>; |
| 323 | |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 324 | def FCMP32rm : Pseudo<(outs), (ins FP32:$src1, rriaddr12:$src2), |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 325 | "ceb\t$src1, $src2", |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 326 | [(SystemZcmp FP32:$src1, (load rriaddr12:$src2)), |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 327 | (implicit PSW)]>; |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 328 | def FCMP64rm : Pseudo<(outs), (ins FP64:$src1, rriaddr12:$src2), |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 329 | "cdb\t$src1, $src2", |
Anton Korobeynikov | 9fa7ded | 2009-07-16 14:33:27 +0000 | [diff] [blame] | 330 | [(SystemZcmp FP64:$src1, (load rriaddr12:$src2)), |
Anton Korobeynikov | 3b6124e | 2009-07-16 14:20:24 +0000 | [diff] [blame] | 331 | (implicit PSW)]>; |
| 332 | } // Defs = [PSW] |
Anton Korobeynikov | d74629f | 2009-07-16 14:24:16 +0000 | [diff] [blame] | 333 | |
| 334 | //===----------------------------------------------------------------------===// |
| 335 | // Non-Instruction Patterns |
| 336 | //===----------------------------------------------------------------------===// |
| 337 | |
| 338 | // Floating point constant -0.0 |
| 339 | def : Pat<(f32 fpimmneg0), (FNEG32rr (LD_Fp032))>; |
| 340 | def : Pat<(f64 fpimmneg0), (FNEG64rr (LD_Fp064))>; |