|
MLIR 22.0.0git
|
Builder for warpgroup ids used to map scf.forall to reindexed warpgroups. More...
#include "mlir/Dialect/GPU/TransformOps/Utils.h"
Public Member Functions | |
| GpuWarpgroupIdBuilder (MLIRContext *ctx, int64_t warpSize, bool useLinearMapping=false, DeviceMaskingAttrInterface mask=nullptr) | |
| Public Member Functions inherited from mlir::transform::gpu::GpuIdBuilder | |
| GpuIdBuilder ()=default | |
| GpuIdBuilder (MLIRContext *ctx, bool useLinearMapping, const MappingIdBuilderFnType &builder) | |
Public Attributes | |
| int64_t | warpSize = 32 |
| Public Attributes inherited from mlir::transform::gpu::GpuIdBuilder | |
| SmallVector< DeviceMappingAttrInterface > | mappingAttributes |
| The mapping attributes targeted by this generator. | |
| GpuIdBuilderFnType | idBuilder |
| The constructor that builds the concrete IR for mapping ids. | |
Static Public Attributes | |
| static constexpr int64_t | kNumWarpsPerGroup = 4 |
| In the future this may be configured by the transformation. | |
Additional Inherited Members | |
| Public Types inherited from mlir::transform::gpu::GpuIdBuilder | |
| using | MappingIdBuilderFnType |
Builder for warpgroup ids used to map scf.forall to reindexed warpgroups.
If useLinearMapping is false, the idBuilder method returns 3D values used for indexing rewrites as well as 3D sizes for predicate generation. If useLinearMapping is true, the idBuilder method returns nD values used for indexing rewrites as well as 1D sizes for predicate generation. If mask is provided, it will be used to filter the active warpgroups.
| mlir::transform::gpu::GpuWarpgroupIdBuilder::GpuWarpgroupIdBuilder | ( | MLIRContext * | ctx, |
| int64_t | warpSize, | ||
| bool | useLinearMapping = false, | ||
| DeviceMaskingAttrInterface | mask = nullptr ) |
Definition at line 307 of file Utils.cpp.
References mlir::transform::gpu::GpuIdBuilder::GpuIdBuilder(), and warpSize.
|
staticconstexpr |
In the future this may be configured by the transformation.
Definition at line 98 of file Utils.h.
Referenced by getThreadIdBuilder().
| int64_t mlir::transform::gpu::GpuWarpgroupIdBuilder::warpSize = 32 |
Definition at line 96 of file Utils.h.
Referenced by GpuWarpgroupIdBuilder().