[llvm] [SPIRV] Add logic for OpGenericCastToPtrExplicit rewriting (PR #146596)

Marcos Maronas via llvm-commits llvm-commits at lists.llvm.org
Thu Jul 3 07:14:16 PDT 2025


================
@@ -0,0 +1,40 @@
+//===- SPIRVTargetTransformInfo.cpp - SPIR-V specific TTI -------*- C++ -*-===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+
+#include "SPIRVTargetTransformInfo.h"
+#include "llvm/IR/IntrinsicsSPIRV.h"
+
+using namespace llvm;
+
+bool llvm::SPIRVTTIImpl::collectFlatAddressOperands(
+    SmallVectorImpl<int> &OpIndexes, Intrinsic::ID IID) const {
+  switch (IID) {
+  case Intrinsic::spv_generic_cast_to_ptr_explicit:
+    OpIndexes.push_back(0);
+    return true;
+  default:
+    return false;
+  }
+}
+
+Value *llvm::SPIRVTTIImpl::rewriteIntrinsicWithAddressSpace(IntrinsicInst *II,
+                                                            Value *OldV,
----------------
maarquitos14 wrote:

Does the compiler not complain about this being unused? 

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


More information about the llvm-commits mailing list