Domain-specific multi-level ir rewriting for gpu: The open earth compiler for gpu-accelerated climate simulation
ACM Transactions on Architecture and Code Optimization (TACO), 2021•dl.acm.org
Most compilers have a single core intermediate representation (IR)(eg, LLVM) sometimes
complemented with vaguely defined IR-like data structures. This IR is commonly low-level
and close to machine instructions. As a result, optimizations relying on domain-specific
information are either not possible or require complex analysis to recover the missing
information. In contrast, multi-level rewriting instantiates a hierarchy of dialects (IRs), lowers
programs level-by-level, and performs code transformations at the most suitable level. We …
complemented with vaguely defined IR-like data structures. This IR is commonly low-level
and close to machine instructions. As a result, optimizations relying on domain-specific
information are either not possible or require complex analysis to recover the missing
information. In contrast, multi-level rewriting instantiates a hierarchy of dialects (IRs), lowers
programs level-by-level, and performs code transformations at the most suitable level. We …
Most compilers have a single core intermediate representation (IR) (e.g., LLVM) sometimes complemented with vaguely defined IR-like data structures. This IR is commonly low-level and close to machine instructions. As a result, optimizations relying on domain-specific information are either not possible or require complex analysis to recover the missing information. In contrast, multi-level rewriting instantiates a hierarchy of dialects (IRs), lowers programs level-by-level, and performs code transformations at the most suitable level. We demonstrate the effectiveness of this approach for the weather and climate domain. In particular, we develop a prototype compiler and design stencil- and GPU-specific dialects based on a set of newly introduced design principles. We find that two domain-specific optimizations (500 lines of code) realized on top of LLVM’s extensible MLIR compiler infrastructure suffice to outperform state-of-the-art solutions. In essence, multi-level rewriting promises to herald the age of specialized compilers composed from domain- and target-specific dialects implemented on top of a shared infrastructure.
data:image/s3,"s3://crabby-images/5f733/5f73387d383596ee6eacd407ec444c9be905a1a4" alt=""