[Mlir-commits] [mlir] [MLIR][GPU][XeVM] Add XeVM target and XeVM dialect integration tests. (PR #148286)
Adam Siemieniuk
llvmlistbot at llvm.org
Mon Aug 11 04:48:26 PDT 2025
================
@@ -0,0 +1,59 @@
+//===-- Utils.h - MLIR XeVM target utils ------------------------*- C++ -*-===//
+//
+// This file is licensed 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
+//
+//===----------------------------------------------------------------------===//
+//
+// This files declares XeVM target related utility classes and functions.
+//
+//===----------------------------------------------------------------------===//
+
+#ifndef MLIR_TARGET_LLVM_XEVM_UTILS_H
+#define MLIR_TARGET_LLVM_XEVM_UTILS_H
+
+#include "mlir/Dialect/GPU/IR/CompilationInterfaces.h"
+#include "mlir/Dialect/LLVMIR/XeVMDialect.h"
+#include "mlir/IR/Attributes.h"
+#include "mlir/Target/LLVM/ModuleToObject.h"
+
+namespace mlir {
+namespace xevm {
+
+/// Base class for all XeVM serializations from GPU modules into binary strings.
+/// By default this class serializes into LLVM bitcode.
+class SerializeGPUModuleBase : public LLVM::ModuleToObject {
+public:
+ SerializeGPUModuleBase(Operation &module, XeVMTargetAttr target,
+ const gpu::TargetOptions &targetOptions = {});
+
+ XeVMTargetAttr getTarget() const;
+
+ /// Loads the bitcode files in `librariesToLink`.
+ std::optional<SmallVector<std::unique_ptr<llvm::Module>>>
+ loadBitcodeFiles(llvm::Module &module) override;
+
+ /// Returns the gpu module being serialized.
+ gpu::GPUModuleOp getGPUModuleOp();
+
+ /// Compiles to native code using `ocloc`.
+ std::optional<SmallVector<char, 0>> compileToBinary(const std::string &asmStr,
+ StringRef inputFormat);
+
+protected:
+ XeVMTargetAttr xeTarget;
+ /// List of LLVM bitcode to link into after translation to LLVM IR.
+ /// The attributes can be StringAttr pointing to a file path, or
+ /// a Resource blob pointing to the LLVM bitcode in-memory.
+ SmallVector<Attribute> librariesToLink;
+
+ /// Returns the path to the tool used for serialization.
+ std::optional<std::string> findTool(StringRef tool);
+
+ gpu::TargetOptions targetOptions;
----------------
adam-smnk wrote:
nit: docs
https://github.com/llvm/llvm-project/pull/148286
More information about the Mlir-commits
mailing list