22#define GEN_PASS_DEF_CONVERTTENSORTOSPIRVPASS
23#include "mlir/Conversion/Passes.h.inc"
30class ConvertTensorToSPIRVPass
34 void runOnOperation()
override {
36 Operation *op = getOperation();
39 std::unique_ptr<ConversionTarget>
target =
43 options.emulateLT32BitScalarTypes = this->emulateLT32BitScalarTypes;
44 options.emulateUnsupportedFloatTypes = this->emulateUnsupportedFloatTypes;
45 SPIRVTypeConverter typeConverter(targetAttr,
options);
48 arith::populateArithToSPIRVPatterns(typeConverter,
patterns);
55 return signalPassFailure();
static llvm::ManagedStatic< PassManagerOptions > options
static std::unique_ptr< SPIRVConversionTarget > get(spirv::TargetEnvAttr targetAttr)
Creates a SPIR-V conversion target for the given target environment.
TargetEnvAttr lookupTargetEnvOrDefault(Operation *op)
Queries the target environment recursively from enclosing symbol table ops containing the given op or...
Include the generated interface declarations.
void populateTensorToSPIRVPatterns(const SPIRVTypeConverter &typeConverter, int64_t byteCountThreshold, RewritePatternSet &patterns)
Appends to a pattern list additional patterns for translating tensor ops to SPIR-V ops.
void populateBuiltinFuncToSPIRVPatterns(const SPIRVTypeConverter &typeConverter, RewritePatternSet &patterns)
Appends to a pattern list additional patterns for translating the builtin func op to the SPIR-V diale...
void populateFuncToSPIRVPatterns(const SPIRVTypeConverter &typeConverter, RewritePatternSet &patterns)
Appends to a pattern list additional patterns for translating Func ops to SPIR-V ops.
const FrozenRewritePatternSet & patterns