MLIR 22.0.0git
XeVMToLLVMIRTranslation.cpp
Go to the documentation of this file.
1//===-- XeVMToLLVMIRTranslation.cpp - Translate XeVM to LLVM IR -*- C++ -*-===//
2//
3// This file is licensed under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file implements a translation between the MLIR XeVM dialect and
10// LLVM IR.
11//
12//===----------------------------------------------------------------------===//
13
17#include "mlir/IR/Operation.h"
19
20#include "llvm/ADT/TypeSwitch.h"
21#include "llvm/IR/Constants.h"
22#include "llvm/IR/LLVMContext.h"
23#include "llvm/IR/Metadata.h"
24
25#include "llvm/IR/ConstantRange.h"
26#include "llvm/IR/IRBuilder.h"
27#include "llvm/Support/raw_ostream.h"
28
29using namespace mlir;
30using namespace mlir::LLVM;
31
32namespace {
33/// Implementation of the dialect interface that converts operations belonging
34/// to the XeVM dialect to LLVM IR.
35class XeVMDialectLLVMIRTranslationInterface
37public:
39
40 /// Attaches module-level metadata for functions marked as kernels.
41 LogicalResult
42 amendOperation(Operation *op, ArrayRef<llvm::Instruction *> instructions,
43 NamedAttribute attribute,
44 LLVM::ModuleTranslation &moduleTranslation) const final {
45 StringRef attrName = attribute.getName().getValue();
46 if (attrName == mlir::xevm::XeVMDialect::getCacheControlsAttrName()) {
47 auto cacheControlsArray = dyn_cast<ArrayAttr>(attribute.getValue());
48 if (cacheControlsArray.size() != 2) {
49 return op->emitOpError(
50 "Expected both L1 and L3 cache control attributes!");
51 }
52 if (instructions.size() != 1) {
53 return op->emitOpError("Expecting a single instruction");
54 }
55 return handleDecorationCacheControl(instructions.front(),
56 cacheControlsArray.getValue());
57 }
58 return success();
59 }
60
61private:
62 static LogicalResult handleDecorationCacheControl(llvm::Instruction *inst,
63 ArrayRef<Attribute> attrs) {
64 SmallVector<llvm::Metadata *> decorations;
65 llvm::LLVMContext &ctx = inst->getContext();
66 llvm::Type *i32Ty = llvm::IntegerType::getInt32Ty(ctx);
67 llvm::transform(
68 attrs, std::back_inserter(decorations),
69 [&ctx, i32Ty](Attribute attr) -> llvm::Metadata * {
70 auto valuesArray = dyn_cast<ArrayAttr>(attr).getValue();
71 std::array<llvm::Metadata *, 4> metadata;
72 llvm::transform(
73 valuesArray, metadata.begin(), [i32Ty](Attribute valueAttr) {
74 return llvm::ConstantAsMetadata::get(llvm::ConstantInt::get(
75 i32Ty, cast<IntegerAttr>(valueAttr).getValue()));
76 });
77 return llvm::MDNode::get(ctx, metadata);
78 });
79 constexpr llvm::StringLiteral decorationCacheControlMDName =
80 "spirv.DecorationCacheControlINTEL";
81 inst->setMetadata(decorationCacheControlMDName,
82 llvm::MDNode::get(ctx, decorations));
83 return success();
84 }
85};
86} // namespace
87
89 registry.insert<xevm::XeVMDialect>();
90 registry.addExtension(+[](MLIRContext *ctx, xevm::XeVMDialect *dialect) {
91 dialect->addInterfaces<XeVMDialectLLVMIRTranslationInterface>();
92 });
93}
94
96 DialectRegistry registry;
98 context.appendDialectRegistry(registry);
99}
return success()
MLIRContext * getContext() const
Return the context that holds the parent dialect of this interface.
Definition Dialect.cpp:117
The DialectRegistry maps a dialect namespace to a constructor for the matching dialect.
bool addExtension(TypeID extensionID, std::unique_ptr< DialectExtensionBase > extension)
Add the given extension to the registry.
Base class for dialect interfaces providing translation to LLVM IR.
MLIRContext is the top-level object for a collection of MLIR operations.
Definition MLIRContext.h:63
void appendDialectRegistry(const DialectRegistry &registry)
Append the contents of the given dialect registry to the registry associated with this context.
Include the generated interface declarations.
void registerXeVMDialectTranslation(mlir::DialectRegistry &registry)
Register the XeVM dialect and the translation from it to the LLVM IR in the given registry;.