Early Experiences With The OpenMP Accelerator Model
Center for Applied Scientific Computing, Lawrence Livermore National Laboratory
9th International Workshop on OpenMP (IWOMP), 2013
@article{liao2013early,
title={Early Experiences With The OpenMP Accelerator Model},
author={Liao, Chunhua and Yan, Yonghong and de Supinski, Bronis R and Quinlan, Daniel J and Chapman, Barbara},
year={2013}
}
A recent trend in mainstream computer nodes is the combined use of general-purpose multicore processors and specialized accelerators such as GPUs and DSPs in order to achieve better performance and to reduce power consumption. To support this trend, the OpenMP Language Committee has approved a set of extensions to OpenMP (referred to as the OpenMP accelerator model). The initial version is the subject of Technical Report 1 (TR1) while OpenMP 4.0 Release Candidate 2 (RC2) further refines the extensions. In this paper, we examine the newly released accelerator directives and create an initial reference implementation, referred to as HOMP (Heterogeneous OpenMP). Focused on targeting NVIDIA GPUs, our work is based on an existing OpenMP implementation in the ROSE source-to-source compiler infrastructure. HOMP includes extensions to parse the new constructs and to represent them in the AST and other compiler translation details. Further we provide initial runtime support. For our evaluation, we have adapted a few existing OpenMP codes to use the accelerator model directives and present preliminary performance results. Finally, we critique the accelerator model in terms of its impact on developers and compiler writers and suggest possible improvements.
July 17, 2013 by hgpu