diff options
author | Benjamin Maxwell <benjamin.maxwell@arm.com> | 2024-12-08 21:29:30 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-12-08 21:29:30 +0000 |
commit | c4aa67e8661c7550dd2d014a991b08eb71566cf7 (patch) | |
tree | 1387f359ead4b1b7fc840e1c88069ef357a8880a /llvm/lib/Analysis/ConstantFolding.cpp | |
parent | 855bc46bc810c4ae97ea9f427429a7efd8b9cc15 (diff) | |
download | llvm-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.cpp | 35 |
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) |