[clang] [CIR] Add address space casts for pointer arguments when creating a call (PR #192303)
Jan Leyonberg via cfe-commits
cfe-commits at lists.llvm.org
Wed Apr 15 12:02:38 PDT 2026
================
@@ -1109,6 +1109,19 @@ RValue CIRGenFunction::emitCall(const CIRGenFunctionInfo &funcInfo,
if (argType != v.getType() && mlir::isa<cir::IntType>(v.getType()))
cgm.errorNYI(loc, "emitCall: widening integer call argument");
+ // If we have a pointer argument and there's an address space mismatch,
+ // insert an address_space cast to match the expected function signature.
+ if (argType != v.getType()) {
----------------
jsjodin wrote:
This is how clang currently handles these. My guess is that lowering may introduce allocas after sema and potentially pass pointers to these as arguments.
https://github.com/llvm/llvm-project/pull/192303
More information about the cfe-commits
mailing list