diff options
| author | Owen Anderson <resistor@mac.com> | 2012-04-05 18:50:32 +0000 |
|---|---|---|
| committer | Owen Anderson <resistor@mac.com> | 2012-04-05 18:50:32 +0000 |
| commit | a6eebf6013172ec16192a9192fd0036014322a32 (patch) | |
| tree | 31f60164f4d5d9b8b4352d16bf2d929780ea81bd /llvm/lib/CodeGen/SelectionDAG | |
| parent | 889a3009a4ade4c465efbfa16021318168780cd8 (diff) | |
| download | bcm5719-llvm-a6eebf6013172ec16192a9192fd0036014322a32.tar.gz bcm5719-llvm-a6eebf6013172ec16192a9192fd0036014322a32.zip | |
Treat f16 the same as f80/f128 for the purposes of generating constants during instruction selection.
llvm-svn: 154113
Diffstat (limited to 'llvm/lib/CodeGen/SelectionDAG')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp b/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp index 305eee81cd9..6e46d4989ad 100644 --- a/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp @@ -62,6 +62,7 @@ static SDVTList makeVTList(const EVT *VTs, unsigned NumVTs) { static const fltSemantics *EVTToAPFloatSemantics(EVT VT) { switch (VT.getSimpleVT().SimpleTy) { default: llvm_unreachable("Unknown FP format"); + case MVT::f16: return &APFloat::IEEEhalf; case MVT::f32: return &APFloat::IEEEsingle; case MVT::f64: return &APFloat::IEEEdouble; case MVT::f80: return &APFloat::x87DoubleExtended; @@ -1042,7 +1043,7 @@ SDValue SelectionDAG::getConstantFP(double Val, EVT VT, bool isTarget) { return getConstantFP(APFloat((float)Val), VT, isTarget); else if (EltVT==MVT::f64) return getConstantFP(APFloat(Val), VT, isTarget); - else if (EltVT==MVT::f80 || EltVT==MVT::f128) { + else if (EltVT==MVT::f80 || EltVT==MVT::f128 || EltVT==MVT::f16) { bool ignored; APFloat apf = APFloat(Val); apf.convert(*EVTToAPFloatSemantics(EltVT), APFloat::rmNearestTiesToEven, |

