[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