[clang] [llvm] [HLSL] Implement the `smoothstep` intrinsic (PR #132288)
Farzon Lotfi via llvm-commits
llvm-commits at lists.llvm.org
Fri Mar 21 11:39:13 PDT 2025
================
@@ -101,6 +101,44 @@ bool SemaSPIRV::CheckSPIRVBuiltinFunctionCall(unsigned BuiltinID,
TheCall->setType(RetTy);
break;
}
+ case SPIRV::BI__builtin_spirv_smoothstep: {
+ if (SemaRef.checkArgCount(TheCall, 3))
+ return true;
+
+ ExprResult A = TheCall->getArg(0);
+ QualType ArgTyA = A.get()->getType();
+ auto *VTyA = ArgTyA->getAs<VectorType>();
+ if (!(ArgTyA->isScalarType() || VTyA)) {
----------------
farzonl wrote:
this conditional is not correct args can ben vector scalar or matrix. There are two checks that make sense here
1. All arguments have `hasFloatingRepresentation`
2. All arguments have the same type.
I don't think you need to do any more than this.
https://github.com/llvm/llvm-project/pull/132288
More information about the llvm-commits
mailing list