Multi-GPU communication schemes for iterative solvers: when CPUs are not in charge

Placeholder

Publication Date

2023

Advisor

Institution Author

Erten, Didem Unat
Sağbili Doğan
Baydamirli Javid
Ismayilov, Ismayil

Co-Authors

Wahib, Mohamed

Journal Title

Journal ISSN

Volume Title

Publisher:

Association for Computing Machinery

Type

Conference proceeding
View PlumX Details

Abstract

This paper proposes a fully autonomous execution model for multi-GPU applications that completely excludes the involvement of the CPU beyond the initial kernel launch. In a typical multi-GPU application, the host serves as the orchestrator of execution by directly launching kernels, issuing communication calls, and acting as a synchronizer for devices. We argue that this orchestration, or control flow path, causes undue overhead and can be delegated entirely to devices to improve performance in applications that require communication among peers. For the proposed CPU-free execution model, we leverage existing techniques such as persistent kernels, thread block specialization, device-side barriers, and device-initiated communication routines to write fully autonomous multi-GPU code and achieve significantly reduced communication overheads. We demonstrate our proposed model on two broadly used iterative solvers, 2D/3D Jacobi stencil and Conjugate Gradient(CG). Compared to the CPU-controlled baselines, the CPU-free model can improve 3D stencil communication latency by 58.8% and provide a 1.63x speedup for CG on 8 NVIDIA A100 GPUs. The project code is available at https://github.com/ParCoreLab/CPU-Free-model. © 2023 Owner/Author(s).

Description

Subject

Computer science

Citation

Endorsement

Review

Supplemented By

Referenced By

Copy Rights Note