[clang] [llvm] [DXIL] implement dot intrinsic lowering for integers (PR #85662)
Chris B via cfe-commits
cfe-commits at lists.llvm.org
Fri Apr 26 08:01:53 PDT 2024
================
@@ -39,11 +39,44 @@ static bool isIntrinsicExpansion(Function &F) {
case Intrinsic::dx_uclamp:
case Intrinsic::dx_lerp:
case Intrinsic::dx_rcp:
+ case Intrinsic::dx_sdot:
+ case Intrinsic::dx_udot:
return true;
}
return false;
}
+static bool expandIntegerDot(CallInst *Orig, Intrinsic::ID DotIntrinsic) {
+ assert(DotIntrinsic == Intrinsic::dx_sdot ||
+ DotIntrinsic == Intrinsic::dx_udot);
+ Intrinsic::ID MadIntrinsic = DotIntrinsic == Intrinsic::dx_sdot
+ ? Intrinsic::dx_imad
+ : Intrinsic::dx_umad;
+ Value *A = Orig->getOperand(0);
+ Value *B = Orig->getOperand(1);
+ Type *ATy = A->getType();
+ Type *BTy = B->getType();
----------------
llvm-beanz wrote:
These two variables are unused in release builds which causes a compiler warning. Can you please either fold them into the assert or mark them as maybe_unused?
https://github.com/llvm/llvm-project/pull/85662
More information about the cfe-commits
mailing list