diff options
| author | Justin Holewinski <justin.holewinski@gmail.com> | 2011-03-14 14:09:33 +0000 |
|---|---|---|
| committer | Justin Holewinski <justin.holewinski@gmail.com> | 2011-03-14 14:09:33 +0000 |
| commit | 8509380f83853e98bf90b57fb690637f8bf4d4ec (patch) | |
| tree | 3771c3d41a992a5291887e448d721be68b20da70 /llvm/lib/Target | |
| parent | a19f075974b79ac93d56b4e23487f22e24eea39e (diff) | |
| download | bcm5719-llvm-8509380f83853e98bf90b57fb690637f8bf4d4ec.tar.gz bcm5719-llvm-8509380f83853e98bf90b57fb690637f8bf4d4ec.zip | |
PTX: Add support for sqrt/sin/cos intrinsics
llvm-svn: 127578
Diffstat (limited to 'llvm/lib/Target')
| -rw-r--r-- | llvm/lib/Target/PTX/PTXInstrInfo.td | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/llvm/lib/Target/PTX/PTXInstrInfo.td b/llvm/lib/Target/PTX/PTXInstrInfo.td index a5f82f1bf38..5c198ca4826 100644 --- a/llvm/lib/Target/PTX/PTXInstrInfo.td +++ b/llvm/lib/Target/PTX/PTXInstrInfo.td @@ -414,6 +414,39 @@ def FDIVri64SM10 : InstPTX<(outs RRegf64:$d), // TODO: Allow the rounding mode to be selectable through llc. defm FMAD : PTX_FLOAT_4OP<"mad.rn", fmul, fadd>; +///===- Floating-Point Intrinsic Instructions -----------------------------===// + +def FSQRT32 : InstPTX<(outs RRegf32:$d), + (ins RRegf32:$a), + "sqrt.rn.f32\t$d, $a", + [(set RRegf32:$d, (fsqrt RRegf32:$a))]>; + +def FSQRT64 : InstPTX<(outs RRegf64:$d), + (ins RRegf64:$a), + "sqrt.rn.f64\t$d, $a", + [(set RRegf64:$d, (fsqrt RRegf64:$a))]>; + +def FSIN32 : InstPTX<(outs RRegf32:$d), + (ins RRegf32:$a), + "sin.approx.f32\t$d, $a", + [(set RRegf32:$d, (fsin RRegf32:$a))]>; + +def FSIN64 : InstPTX<(outs RRegf64:$d), + (ins RRegf64:$a), + "sin.approx.f64\t$d, $a", + [(set RRegf64:$d, (fsin RRegf64:$a))]>; + +def FCOS32 : InstPTX<(outs RRegf32:$d), + (ins RRegf32:$a), + "cos.approx.f32\t$d, $a", + [(set RRegf32:$d, (fcos RRegf32:$a))]>; + +def FCOS64 : InstPTX<(outs RRegf64:$d), + (ins RRegf64:$a), + "cos.approx.f64\t$d, $a", + [(set RRegf64:$d, (fcos RRegf64:$a))]>; + + ///===- Comparison and Selection Instructions -----------------------------===// defm SETPEQu32 : PTX_SETP<RRegu32, "u32", i32imm, SETEQ, "eq">; |

