[clang] [llvm] [HLSL][DXIL] Implement `asdouble` intrinsic (PR #114847)
via llvm-commits
llvm-commits at lists.llvm.org
Tue Nov 5 09:12:38 PST 2024
================
@@ -1870,6 +1870,23 @@ bool SemaHLSL::CheckBuiltinFunctionCall(unsigned BuiltinID, CallExpr *TheCall) {
return true;
break;
}
+ case Builtin::BI__builtin_hlsl_asdouble: {
+ if (SemaRef.checkArgCount(TheCall, 2))
+ return true;
+ if (CheckUnsignedIntRepresentation(&SemaRef, TheCall))
+ return true;
+
+ // Set the return type to be a scalar or vector of same length of double
+ ASTContext &Ctx = SemaRef.getASTContext();
+ auto *VTy = TheCall->getArg(0)->getType()->getAs<VectorType>();
+
+ QualType ResultType =
+ VTy ? Ctx.getVectorType(Ctx.DoubleTy, VTy->getNumElements(),
+ VTy->getVectorKind())
+ : Ctx.DoubleTy;
+ TheCall->setType(ResultType);
----------------
joaosaffran wrote:
Can we use `SetElementTypeAsReturnType` here ?
https://github.com/llvm/llvm-project/pull/114847
More information about the llvm-commits
mailing list