Skip to content
  • George Mitenkov's avatar
    89808ce7
    [MLIR][mlir-spirv-cpu-runner] A SPIR-V cpu runner prototype · 89808ce7
    George Mitenkov authored
    This patch introduces a SPIR-V runner. The aim is to run a gpu
    kernel on a CPU via GPU -> SPIRV -> LLVM conversions. This is a first
    prototype, so more features will be added in due time.
    
    - Overview
    The runner follows similar flow as the other runners in-tree. However,
    having converted the kernel to SPIR-V, we encode the bind attributes of
    global variables that represent kernel arguments. Then SPIR-V module is
    converted to LLVM. On the host side, we emulate passing the data to device
    by creating in main module globals with the same symbolic name as in kernel
    module. These global variables are later linked with ones from the nested
    module. We copy data from kernel arguments to globals, call the kernel
    function from nested module and then copy the data back.
    
    - Current state
    At the moment, the runner is capable of running 2 modules, nested one in
    another. The kernel module must contain exactly one kernel function. Also,
    the runner supports rank 1 integer memref types as arguments (to be scaled).
    
    - Enhancement of JitRunner and ExecutionEngine
    To translate nested modules to LLVM IR, JitRunner and ExecutionEngine were
    altered to take an optional (default to `nullptr`) function reference that
    is a custom LLVM IR module builder. This allows to customize LLVM IR module
    creation from MLIR modules.
    
    Reviewed By: ftynse, mravishankar
    
    Differential Revision: https://reviews.llvm.org/D86108
    89808ce7
    [MLIR][mlir-spirv-cpu-runner] A SPIR-V cpu runner prototype
    George Mitenkov authored
    This patch introduces a SPIR-V runner. The aim is to run a gpu
    kernel on a CPU via GPU -> SPIRV -> LLVM conversions. This is a first
    prototype, so more features will be added in due time.
    
    - Overview
    The runner follows similar flow as the other runners in-tree. However,
    having converted the kernel to SPIR-V, we encode the bind attributes of
    global variables that represent kernel arguments. Then SPIR-V module is
    converted to LLVM. On the host side, we emulate passing the data to device
    by creating in main module globals with the same symbolic name as in kernel
    module. These global variables are later linked with ones from the nested
    module. We copy data from kernel arguments to globals, call the kernel
    function from nested module and then copy the data back.
    
    - Current state
    At the moment, the runner is capable of running 2 modules, nested one in
    another. The kernel module must contain exactly one kernel function. Also,
    the runner supports rank 1 integer memref types as arguments (to be scaled).
    
    - Enhancement of JitRunner and ExecutionEngine
    To translate nested modules to LLVM IR, JitRunner and ExecutionEngine were
    altered to take an optional (default to `nullptr`) function reference that
    is a custom LLVM IR module builder. This allows to customize LLVM IR module
    creation from MLIR modules.
    
    Reviewed By: ftynse, mravishankar
    
    Differential Revision: https://reviews.llvm.org/D86108
Loading