G10: Enabling An Efficient Unified GPU Memory and Storage Architecture with Smart Tensor Migrations
This addresses scalability issues for deep learning workloads by enabling efficient memory management without code modifications, though it is an incremental improvement on existing memory extension techniques.
The paper tackles the GPU memory wall problem in deep learning by proposing G10, a unified GPU memory and storage architecture that integrates host memory, GPU memory, and flash memory with smart tensor migrations, achieving up to 1.75x performance improvement over state-of-the-art solutions and reaching 90.3% of ideal performance with unlimited GPU memory.
To break the GPU memory wall for scaling deep learning workloads, a variety of architecture and system techniques have been proposed recently. Their typical approaches include memory extension with flash memory and direct storage access. However, these techniques still suffer from suboptimal performance and introduce complexity to the GPU memory management, making them hard to meet the scalability requirement of deep learning workloads today. In this paper, we present a unified GPU memory and storage architecture named G10 driven by the fact that the tensor behaviors of deep learning workloads are highly predictable. G10 integrates the host memory, GPU memory, and flash memory into a unified memory space, to scale the GPU memory capacity while enabling transparent data migrations. Based on this unified GPU memory and storage architecture, G10 utilizes compiler techniques to characterize the tensor behaviors in deep learning workloads. Therefore, it can schedule data migrations in advance by considering the available bandwidth of flash memory and host memory. The cooperative mechanism between deep learning compilers and the unified memory architecture enables G10 to hide data transfer overheads in a transparent manner. We implement G10 based on an open-source GPU simulator. Our experiments demonstrate that G10 outperforms state-of-the-art GPU memory solutions by up to 1.75$\times$, without code modifications to deep learning workloads. With the smart data migration mechanism, G10 can reach 90.3\% of the performance of the ideal case assuming unlimited GPU memory.