[Mlir-commits] [mlir] 620c383 - [mlir][nfc] De-duplicate tests from `Type::isIntOrFloat` (#129710)
llvmlistbot at llvm.org
llvmlistbot at llvm.org
Thu Mar 6 01:04:33 PST 2025
Author: Andrzej WarzyĆski
Date: 2025-03-06T09:04:30Z
New Revision: 620c38371de46d45e9095936c823e3e40a2c5f64
URL: https://github.com/llvm/llvm-project/commit/620c38371de46d45e9095936c823e3e40a2c5f64
DIFF: https://github.com/llvm/llvm-project/commit/620c38371de46d45e9095936c823e3e40a2c5f64.diff
LOG: [mlir][nfc] De-duplicate tests from `Type::isIntOrFloat` (#129710)
This PR makes sure that we always use `Type::isIntOrFloat` rather than
re-implementing this condition inline. Also, it removes `isScalarType`
that effectively re-implemented this method.
Added:
Modified:
mlir/lib/Interfaces/DataLayoutInterfaces.cpp
mlir/lib/Target/LLVMIR/ModuleImport.cpp
Removed:
################################################################################
diff --git a/mlir/lib/Interfaces/DataLayoutInterfaces.cpp b/mlir/lib/Interfaces/DataLayoutInterfaces.cpp
index 2b35e39a24e7a..2d098e2db6a96 100644
--- a/mlir/lib/Interfaces/DataLayoutInterfaces.cpp
+++ b/mlir/lib/Interfaces/DataLayoutInterfaces.cpp
@@ -51,7 +51,7 @@ mlir::detail::getDefaultTypeSize(Type type, const DataLayout &dataLayout,
llvm::TypeSize
mlir::detail::getDefaultTypeSizeInBits(Type type, const DataLayout &dataLayout,
DataLayoutEntryListRef params) {
- if (isa<IntegerType, FloatType>(type))
+ if (type.isIntOrFloat())
return llvm::TypeSize::getFixed(type.getIntOrFloatBitWidth());
if (auto ctype = dyn_cast<ComplexType>(type)) {
@@ -745,7 +745,7 @@ LogicalResult mlir::detail::verifyDataLayoutSpec(DataLayoutSpecInterface spec,
continue;
}
- if (isa<IntegerType, FloatType>(sampleType)) {
+ if (sampleType.isIntOrFloat()) {
for (DataLayoutEntryInterface entry : kvp.second) {
auto value = dyn_cast<DenseIntElementsAttr>(entry.getValue());
if (!value || !value.getElementType().isSignlessInteger(64)) {
diff --git a/mlir/lib/Target/LLVMIR/ModuleImport.cpp b/mlir/lib/Target/LLVMIR/ModuleImport.cpp
index 2d3c0efd9a972..823e5f07a7539 100644
--- a/mlir/lib/Target/LLVMIR/ModuleImport.cpp
+++ b/mlir/lib/Target/LLVMIR/ModuleImport.cpp
@@ -759,11 +759,6 @@ void ModuleImport::setFastmathFlagsAttr(llvm::Instruction *inst,
iface->setAttr(iface.getFastmathAttrName(), attr);
}
-/// Returns if `type` is a scalar integer or floating-point type.
-static bool isScalarType(Type type) {
- return isa<IntegerType, FloatType>(type);
-}
-
/// Returns `type` if it is a builtin integer or floating-point vector type that
/// can be used to create an attribute or nullptr otherwise. If provided,
/// `arrayShape` is added to the shape of the vector to create an attribute that
@@ -781,7 +776,7 @@ static Type getVectorTypeForAttr(Type type, ArrayRef<int64_t> arrayShape = {}) {
// An LLVM dialect vector can only contain scalars.
Type elementType = LLVM::getVectorElementType(type);
- if (!isScalarType(elementType))
+ if (!elementType.isIntOrFloat())
return {};
SmallVector<int64_t> shape(arrayShape);
@@ -794,7 +789,7 @@ Type ModuleImport::getBuiltinTypeForAttr(Type type) {
return {};
// Return builtin integer and floating-point types as is.
- if (isScalarType(type))
+ if (type.isIntOrFloat())
return type;
// Return builtin vectors of integer and floating-point types as is.
@@ -808,7 +803,7 @@ Type ModuleImport::getBuiltinTypeForAttr(Type type) {
arrayShape.push_back(arrayType.getNumElements());
type = arrayType.getElementType();
}
- if (isScalarType(type))
+ if (type.isIntOrFloat())
return RankedTensorType::get(arrayShape, type);
return getVectorTypeForAttr(type, arrayShape);
}
More information about the Mlir-commits
mailing list