//===- ArmSVEDialect.cpp - MLIR ArmSVE dialect implementation -------------===// // // 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 // //===----------------------------------------------------------------------===// // // This file implements the ArmSVE dialect and its operations. // //===----------------------------------------------------------------------===// #include "mlir/Dialect/ArmSVE/IR/ArmSVEDialect.h" #include "mlir/Dialect/LLVMIR/LLVMTypes.h" #include "mlir/Dialect/Vector/IR/VectorOps.h" #include "mlir/IR/Builders.h" #include "mlir/IR/DialectImplementation.h" #include "mlir/IR/OpImplementation.h" #include "mlir/IR/TypeUtilities.h" #include "llvm/ADT/TypeSwitch.h" usingnamespacemlir; usingnamespacemlir::arm_sve; //===----------------------------------------------------------------------===// // ScalableVector versions of general helpers for comparison ops //===----------------------------------------------------------------------===// /// Return the scalable vector of the same shape and containing i1. static Type getI1SameShape(Type type) { … } //===----------------------------------------------------------------------===// // Tablegen Definitions //===----------------------------------------------------------------------===// #include "mlir/Dialect/ArmSVE/IR/ArmSVEDialect.cpp.inc" #define GET_OP_CLASSES #include "mlir/Dialect/ArmSVE/IR/ArmSVE.cpp.inc" #define GET_TYPEDEF_CLASSES #include "mlir/Dialect/ArmSVE/IR/ArmSVETypes.cpp.inc" void ArmSVEDialect::initialize() { … }