License: Creative Commons Attribution 3.0 Unported license (CC BY 3.0)
When quoting this document, please refer to the following
DOI: 10.4230/LIPIcs.ECRTS.2019.22
URN: urn:nbn:de:0030-drops-107595
URL: http://dagstuhl.sunsite.rwth-aachen.de/volltexte/2019/10759/
Cavicchioli, Roberto ;
Capodieci, Nicola ;
Solieri, Marco ;
Bertogna, Marko
Novel Methodologies for Predictable CPU-To-GPU Command Offloading
Abstract
There is an increasing industrial and academic interest towards a more predictable characterization of real-time tasks on high-performance heterogeneous embedded platforms, where a host system offloads parallel workloads to an integrated accelerator, such as General Purpose-Graphic Processing Units (GP-GPUs). In this paper, we analyze an important aspect that has not yet been considered in the real-time literature, and that may significantly affect real-time performance if not properly treated, i.e., the time spent by the CPU for submitting GP-GPU operations. We will show that the impact of CPU-to-GPU kernel submissions may be indeed relevant for typical real-time workloads, and that it should be properly factored in when deriving an integrated schedulability analysis for the considered platforms.
This is the case when an application is composed of many small and consecutive GPU compute/copy operations. While existing techniques mitigate this issue by batching kernel calls into a reduced number of persistent kernel invocations, in this work we present and evaluate three other approaches that are made possible by recently released versions of the NVIDIA CUDA GP-GPU API, and by Vulkan, a novel open standard GPU API that allows an improved control of GPU command submissions. We will show that this added control may significantly improve the application performance and predictability due to a substantial reduction in CPU-to-GPU driver interactions, making Vulkan an interesting candidate for becoming the state-of-the-art API for heterogeneous Real-Time systems.
Our findings are evaluated on a latest generation NVIDIA Jetson AGX Xavier embedded board, executing typical workloads involving Deep Neural Networks of parameterized complexity.
BibTeX - Entry
@InProceedings{cavicchioli_et_al:LIPIcs:2019:10759,
author = {Roberto Cavicchioli and Nicola Capodieci and Marco Solieri and Marko Bertogna},
title = {{Novel Methodologies for Predictable CPU-To-GPU Command Offloading}},
booktitle = {31st Euromicro Conference on Real-Time Systems (ECRTS 2019)},
pages = {22:1--22:22},
series = {Leibniz International Proceedings in Informatics (LIPIcs)},
ISBN = {978-3-95977-110-8},
ISSN = {1868-8969},
year = {2019},
volume = {133},
editor = {Sophie Quinton},
publisher = {Schloss Dagstuhl--Leibniz-Zentrum fuer Informatik},
address = {Dagstuhl, Germany},
URL = {http://drops.dagstuhl.de/opus/volltexte/2019/10759},
URN = {urn:nbn:de:0030-drops-107595},
doi = {10.4230/LIPIcs.ECRTS.2019.22},
annote = {Keywords: Heterogeneous systems, GPU, CUDA, Vulkan}
}
Keywords: |
|
Heterogeneous systems, GPU, CUDA, Vulkan |
Collection: |
|
31st Euromicro Conference on Real-Time Systems (ECRTS 2019) |
Issue Date: |
|
2019 |
Date of publication: |
|
02.07.2019 |
Supplementary Material: |
|
ECRTS 2019 Artifact Evaluation approved artifact available at https://dx.doi.org/10.4230/DARTS.5.1.4 |