[clang] [HLSL] get inout/out ABI for array parameters working (PR #111047)

Chris B via cfe-commits cfe-commits at lists.llvm.org
Tue Dec 3 13:49:34 PST 2024


================
@@ -5322,6 +5324,11 @@ RValue CodeGenFunction::EmitCall(const CGFunctionInfo &CallInfo,
           IRCallArgs[FirstIRArg] = Val;
           break;
         }
+      } else if (I->getType()->isArrayParameterType()) {
+        // use the tmp created by the HLSLOutArgExpr
+        // instead of creating a new one below and copying the tmp into it.
+        IRCallArgs[FirstIRArg] = I->getKnownRValue().getScalarVal();
+        break;
----------------
llvm-beanz wrote:

Bleh... I spent some time today looking at this, and I think I've convinced myself that this is probably the simplest approach.

Without this you get a redundant copy because the cast that produces the ArrayParameterType. I have one small request to change the comment above.

https://github.com/llvm/llvm-project/pull/111047


More information about the cfe-commits mailing list