AUTHOR=Thomadakis Polykarpos , Chrisochoides Nikos TITLE=Runtime support for CPU-GPU high-performance computing on distributed memory platforms JOURNAL=Frontiers in High Performance Computing VOLUME=2 YEAR=2024 URL=https://www.frontiersin.org/journals/high-performance-computing/articles/10.3389/fhpcp.2024.1417040 DOI=10.3389/fhpcp.2024.1417040 ISSN=2813-7337 ABSTRACT=Introduction

Hardware heterogeneity is here to stay for high-performance computing. Large-scale systems are currently equipped with multiple GPU accelerators per compute node and are expected to incorporate more specialized hardware. This shift in the computing ecosystem offers many opportunities for performance improvement; however, it also increases the complexity of programming for such architectures.

Methods

This work introduces a runtime framework that enables effortless programming for heterogeneous systems while efficiently utilizing hardware resources. The framework is integrated within a distributed and scalable runtime system to facilitate performance portability across heterogeneous nodes. Along with the design, this paper describes the implementation and optimizations performed, achieving up to 300% improvement on a single device and linear scalability on a node equipped with four GPUs.

Results

The framework in a distributed memory environment offers portable abstractions that enable efficient inter-node communication among devices with varying capabilities. It delivers superior performance compared to MPI+CUDA by up to 20% for large messages while keeping the overheads for small messages within 10%. Furthermore, the results of our performance evaluation in a distributed Jacobi proxy application demonstrate that our software imposes minimal overhead and achieves a performance improvement of up to 40%.

Discussion

This is accomplished by the optimizations at the library level and by creating opportunities to leverage application-specific optimizations like over-decomposition.