[clang] [llvm] [AMDGPU] Add OpenCL-specific fence address space masks (PR #78572)

Matt Arsenault via cfe-commits cfe-commits at lists.llvm.org
Wed Apr 24 00:52:31 PDT 2024


================
@@ -18319,6 +18320,26 @@ Value *CodeGenFunction::EmitHLSLBuiltinExpr(unsigned BuiltinID,
   return nullptr;
 }
 
+void CodeGenFunction::AddAMDGCNAddressSpaceMMRA(llvm::Instruction *Inst,
+                                                llvm::Value *ASMask) {
+  constexpr const char *Tag = "opencl-fence-mem";
+
+  uint64_t Mask = cast<llvm::ConstantInt>(ASMask)->getZExtValue();
+  if (Mask == 0)
+    return;
+
+  // 3 bits can be set: local, global, image in that order.
+  LLVMContext &Ctx = Inst->getContext();
+  SmallVector<MMRAMetadata::TagT, 3> MMRAs;
+  if (Mask & (1 << 0))
----------------
arsenm wrote:

Alternatively could behave more like system scopes where the builtin takes a variadic list of string literal arguments passed directly through 

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


More information about the cfe-commits mailing list