[llvm] [SPIR-V] Ensure that a correct pointer type is deduced from the Value argument of OpAtomic* instructions (PR #127492)

Dmitry Sidorov via llvm-commits llvm-commits at lists.llvm.org
Mon Feb 17 06:22:52 PST 2025


================
@@ -934,9 +937,23 @@ bool SPIRVEmitIntrinsics::deduceOperandElementTypeCalledFunction(
       case SPIRV::OpAtomicUMax:
       case SPIRV::OpAtomicSMin:
       case SPIRV::OpAtomicSMax: {
-        KnownElemTy = getAtomicElemTy(GR, CI, Op);
+        KnownElemTy = isPointerTy(CI->getType()) ? getAtomicElemTy(GR, CI, Op)
+                                                 : CI->getType();
         if (!KnownElemTy)
           return true;
+        Uncomplete = isTodoType(Op);
+        Ops.push_back(std::make_pair(Op, 0));
+      } break;
+      case SPIRV::OpAtomicStore: {
+        if (CI->arg_size() < 4)
+          return true;
+        Value *ValOp = CI->getArgOperand(3);
+        KnownElemTy = isPointerTy(ValOp->getType())
+                          ? getAtomicElemTy(GR, CI, Op)
+                          : ValOp->getType();
+        if (!KnownElemTy)
+          return true;
+        Uncomplete = isTodoType(Op);
----------------
MrSidims wrote:

... so if the idea to set that the type is TBD, then parameter should be name `Incomplete` (and please accept my apologies for such nitpicking :) )

Also, I don't see `Un/Incomplete` variable to be really used in the code (originally based on the name I though there would be
```
 if (Uncomplete) {
 /* store something and do early exit */
 }
```

but seems like it's added as a function parameter just to silence the warning of the unused return from `isTodoType`, or am I missing something?

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


More information about the llvm-commits mailing list