diff options
author | martin-luecke <martin.luecke@ed.ac.uk> | 2023-12-15 13:04:43 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-12-15 13:04:43 +0100 |
commit | 681eacc1b670fd7137d8677fef6fc76c6e37dca9 (patch) | |
tree | a3f0351ced882ffd3be6dd3ecd9965972d373c2e /llvm/lib/Target/AMDGPU/SILoadStoreOptimizer.cpp | |
parent | f0b44ce28eaf3dbea557f36b6bd1d9fcd7c084b8 (diff) | |
download | llvm-681eacc1b670fd7137d8677fef6fc76c6e37dca9.zip llvm-681eacc1b670fd7137d8677fef6fc76c6e37dca9.tar.gz llvm-681eacc1b670fd7137d8677fef6fc76c6e37dca9.tar.bz2 |
[MLIR][transform][python] add sugared python abstractions for transform dialect (#75073)
This adds Python abstractions for the different handle types of the
transform dialect
The abstractions allow for straightforward chaining of transforms by
calling their member functions.
As an initial PR for this infrastructure, only a single transform is
included: `transform.structured.match`.
With a future `tile` transform abstraction an example of the usage is:
```Python
def script(module: OpHandle):
module.match_ops(MatchInterfaceEnum.TilingInterface).tile(tile_sizes=[32,32])
```
to generate the following IR:
```mlir
%0 = transform.structured.match interface{TilingInterface} in %arg0
%tiled_op, %loops = transform.structured.tile_using_for %0 [32, 32]
```
These abstractions are intended to enhance the usability and flexibility
of the transform dialect by providing an accessible interface that
allows for easy assembly of complex transformation chains.
Diffstat (limited to 'llvm/lib/Target/AMDGPU/SILoadStoreOptimizer.cpp')
0 files changed, 0 insertions, 0 deletions