Skip to Main content Skip to Navigation
Conference papers

Adaptive Runtime Selection for GPU

Jean-François Dollinger 1, 2 Vincent Loechner 1, 3
1 CAMUS - Compilation pour les Architectures MUlti-coeurS
LSIIT - Laboratoire des Sciences de l'Image, de l'Informatique et de la Télédétection, Inria Nancy - Grand Est
ICube - Laboratoire des sciences de l'ingénieur, de l'informatique et de l'imagerie
Abstract : It is often hard to predict the performance of a statically generated code. Hardware availability, hardware specification and problem size may change from one execution context to another. The main contribution of this work is an entirely automatic method aiming to predict execution times of semantically equivalent versions of affine loop nests on GPUs; then, to run the best performing one on GPU or CPU. To make accurate predictions, our framework relies on three consecutive stages: a static code generation, an offline profiling and an online prediction. Different versions are statically gen- erated by PPCG, a source-to-source polyhedral compiler, able to generate CUDA code from static control loops written in C. The code versions differ by their block sizes, tiling and parallel schedule. The profiling code carries out the required measurements on the target machine: throughput between host and device memory, and execution time of the kernels with various parameters. At runtime, we rely on those results to calculate a predicted execution time on GPU. This is followed by a "fastest wins" algorithm, that runs instances of the target code concurrently on CPU and GPU; the first completed kills the other one. We validate this proposal on the polyhedral benchmark suite, showing that the predictions are accurate and that the runtime selection is effective on two different architectures.
Complete list of metadata
Contributor : Vincent Loechner Connect in order to contact the contributor
Submitted on : Thursday, October 3, 2013 - 6:21:01 PM
Last modification on : Thursday, December 2, 2021 - 3:45:57 AM



Jean-François Dollinger, Vincent Loechner. Adaptive Runtime Selection for GPU. 42nd International Conference on Parallel Processing, 2013, Lyon, France. pp.70-79, ⟨10.1109/ICPP.2013.16⟩. ⟨hal-00869652⟩



Record views