summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms
diff options
context:
space:
mode:
authorMatt Arsenault <Matthew.Arsenault@amd.com>2016-03-30 22:28:52 +0000
committerMatt Arsenault <Matthew.Arsenault@amd.com>2016-03-30 22:28:52 +0000
commit2fe4fbc1843019d804b33117bc006a2a8ba89f6a (patch)
tree96e2c438ebb265aff8c5f079284c586c29732511 /llvm/lib/Transforms
parent5cd4f8f89fabe411445bb11c21add4fa7308e74b (diff)
downloadbcm5719-llvm-2fe4fbc1843019d804b33117bc006a2a8ba89f6a.tar.gz
bcm5719-llvm-2fe4fbc1843019d804b33117bc006a2a8ba89f6a.zip
AMDGPU: Add frexp_exp intrinsic
llvm-svn: 264944
Diffstat (limited to 'llvm/lib/Transforms')
-rw-r--r--llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp21
1 files changed, 16 insertions, 5 deletions
diff --git a/llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp b/llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp
index 19d81fac778..3132fe86c47 100644
--- a/llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp
+++ b/llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp
@@ -1846,17 +1846,28 @@ Instruction *InstCombiner::visitCallInst(CallInst &CI) {
break;
}
- case Intrinsic::amdgcn_frexp_mant: {
+ case Intrinsic::amdgcn_frexp_mant:
+ case Intrinsic::amdgcn_frexp_exp: {
Value *Src = II->getArgOperand(0);
if (const ConstantFP *C = dyn_cast<ConstantFP>(Src)) {
int Exp;
APFloat Significand = frexp(C->getValueAPF(), Exp,
APFloat::rmNearestTiesToEven);
- return replaceInstUsesWith(CI, ConstantFP::get(II->getContext(),
- Significand));
- } else if (isa<UndefValue>(Src))
- return replaceInstUsesWith(CI, Src);
+ if (II->getIntrinsicID() == Intrinsic::amdgcn_frexp_mant) {
+ return replaceInstUsesWith(CI, ConstantFP::get(II->getContext(),
+ Significand));
+ }
+
+ // Match instruction special case behavior.
+ if (Exp == APFloat::IEK_NaN || Exp == APFloat::IEK_Inf)
+ Exp = 0;
+
+ return replaceInstUsesWith(CI, ConstantInt::get(II->getType(), Exp));
+ }
+
+ if (isa<UndefValue>(Src))
+ return replaceInstUsesWith(CI, UndefValue::get(II->getType()));
break;
}
OpenPOWER on IntegriCloud