aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Analysis/ConstantFolding.cpp
diff options
context:
space:
mode:
authorBenjamin Maxwell <benjamin.maxwell@arm.com>2024-12-08 21:29:30 +0000
committerGitHub <noreply@github.com>2024-12-08 21:29:30 +0000
commitc4aa67e8661c7550dd2d014a991b08eb71566cf7 (patch)
tree1387f359ead4b1b7fc840e1c88069ef357a8880a /llvm/lib/Analysis/ConstantFolding.cpp
parent855bc46bc810c4ae97ea9f427429a7efd8b9cc15 (diff)
downloadllvm-c4aa67e8661c7550dd2d014a991b08eb71566cf7.zip
llvm-c4aa67e8661c7550dd2d014a991b08eb71566cf7.tar.gz
llvm-c4aa67e8661c7550dd2d014a991b08eb71566cf7.tar.bz2
Revert "[InstSimplify] Add basic constant folding for `llvm.sincos`" (#119149)
Reverts llvm/llvm-project#114527 Reverting due to buildbot failures (e.g. https://lab.llvm.org/buildbot/#/builders/180/builds/9685)
Diffstat (limited to 'llvm/lib/Analysis/ConstantFolding.cpp')
-rw-r--r--llvm/lib/Analysis/ConstantFolding.cpp35
1 files changed, 0 insertions, 35 deletions
diff --git a/llvm/lib/Analysis/ConstantFolding.cpp b/llvm/lib/Analysis/ConstantFolding.cpp
index 0233d31..efbccee 100644
--- a/llvm/lib/Analysis/ConstantFolding.cpp
+++ b/llvm/lib/Analysis/ConstantFolding.cpp
@@ -1632,7 +1632,6 @@ bool llvm::canConstantFoldCallTo(const CallBase *Call, const Function *F) {
case Intrinsic::sqrt:
case Intrinsic::sin:
case Intrinsic::cos:
- case Intrinsic::sincos:
case Intrinsic::pow:
case Intrinsic::powi:
case Intrinsic::ldexp:
@@ -3535,40 +3534,6 @@ ConstantFoldStructCall(StringRef Name, Intrinsic::ID IntrinsicID,
return nullptr;
return ConstantStruct::get(StTy, Result0, Result1);
}
- case Intrinsic::sincos: {
- Type *Ty = StTy->getContainedType(0);
- Type *TyScalar = Ty->getScalarType();
-
- auto ConstantFoldScalarSincosCall =
- [&](Constant *Op) -> std::pair<Constant *, Constant *> {
- Constant *SinResult =
- ConstantFoldScalarCall(Name, Intrinsic::sin, TyScalar, Op, TLI, Call);
- Constant *CosResult =
- ConstantFoldScalarCall(Name, Intrinsic::cos, TyScalar, Op, TLI, Call);
- return std::make_pair(SinResult, CosResult);
- };
-
- if (auto *FVTy = dyn_cast<FixedVectorType>(Ty)) {
- SmallVector<Constant *> SinResults(FVTy->getNumElements());
- SmallVector<Constant *> CosResults(FVTy->getNumElements());
-
- for (unsigned I = 0, E = FVTy->getNumElements(); I != E; ++I) {
- Constant *Lane = Operands[0]->getAggregateElement(I);
- std::tie(SinResults[I], CosResults[I]) =
- ConstantFoldScalarSincosCall(Lane);
- if (!SinResults[I] || !CosResults[I])
- return nullptr;
- }
-
- return ConstantStruct::get(StTy, ConstantVector::get(SinResults),
- ConstantVector::get(CosResults));
- }
-
- auto [SinResult, CosResult] = ConstantFoldScalarSincosCall(Operands[0]);
- if (!SinResult || !CosResult)
- return nullptr;
- return ConstantStruct::get(StTy, SinResult, CosResult);
- }
default:
// TODO: Constant folding of vector intrinsics that fall through here does
// not work (e.g. overflow intrinsics)