[clang] [Clang] VectorExprEvaluator::VisitCallExpr / InterpretBuiltin - allow MMX/SSE/AVX2 PSIGN intrinsics to be used in constexpr (PR #163685)
Simon Pilgrim via cfe-commits
cfe-commits at lists.llvm.org
Wed Oct 22 01:14:45 PDT 2025
================
@@ -12312,6 +12312,21 @@ bool VectorExprEvaluator::VisitCallExpr(const CallExpr *E) {
return Success(APValue(ResultElements.data(), ResultElements.size()), E);
}
+ case X86::BI__builtin_ia32_psignb128:
+ case X86::BI__builtin_ia32_psignb256:
+ case X86::BI__builtin_ia32_psignw128:
+ case X86::BI__builtin_ia32_psignw256:
+ case X86::BI__builtin_ia32_psignd128:
+ case X86::BI__builtin_ia32_psignd256:
+ return EvaluateBinOpExpr(
+ [](const APInt &AElem, const APInt &BElem) -> APInt {
----------------
RKSimon wrote:
```suggestion
[](const APInt &AElem, const APInt &BElem) {
```
https://github.com/llvm/llvm-project/pull/163685
More information about the cfe-commits
mailing list