The MLIR Transform Dialect. Your compiler is more powerful than you think
Martin Paul Lücke, Oleksandr Zinenko, William S. Moses, Michel Steuwer, Albert Cohen
TL;DR
The paper tackles the challenge of insufficient, coarse-grained compiler control in heterogeneous hardware contexts by introducing the MLIR Transform dialect, an IR-based transformation language that lets performance engineers compose and steer existing compiler features without rebuilding the compiler. It delivers an interpretable Transform IR, handles, and parameters, plus static and dynamic verification through pre-/post-conditions and IRDL-based checks, enabling robust, reusable transformation pipelines. Five case studies demonstrate expressiveness, low overhead (up to $2.6\%$ compile-time), and practical benefits such as debugging optimization patterns, fine-grained performance tuning, and autotuning-driven exploration. The work significantly broadens access to domain knowledge in compilation, enables tight integration with optimization search methods, and supports scalable, portable, and high-performance code generation across dialects and targets.
Abstract
To take full advantage of a specific hardware target, performance engineers need to gain control on compilers in order to leverage their domain knowledge about the program and hardware. Yet, modern compilers are poorly controlled, usually by configuring a sequence of coarse-grained monolithic black-box passes, or by means of predefined compiler annotations/pragmas. These can be effective, but often do not let users precisely optimize their varying compute loads. As a consequence, performance engineers have to resort to implementing custom passes for a specific optimization heuristic, requiring compiler engineering expert knowledge. In this paper, we present a technique that provides fine-grained control of general-purpose compilers by introducing the Transform dialect, a controllable IR-based transformation system implemented in MLIR. The Transform dialect empowers performance engineers to optimize their various compute loads by composing and reusing existing - but currently hidden - compiler features without the need to implement new passes or even rebuilding the compiler. We demonstrate in five case studies that the Transform dialect enables precise, safe composition of compiler transformations and allows for straightforward integration with state-of-the-art search methods.
