Publication

Clacc: Translating OpenACC to OpenMP in Clang

Citation

Clacc: Translating OpenACC to OpenMP in Clang, Joel E. Denny, Seyong Lee, and Jeffrey S. Vetter, 2018 IEEE/ACM 5th Workshop on the LLVM Compiler Infrastructure in HPC (LLVM-HPC), Dallas, TX, USA, (2018).

Abstract

OpenACC was launched in 2010 as a portable programming model for heterogeneous accelerators.  Although various implementations already exist, no extensible, open-source, production-quality compiler support is available to the community.  This deficiency poses a serious risk for HPC application developers targeting GPUs and other accelerators, and it limits experimentation and progress for the OpenACC specification.  To address this deficiency, Clacc is a recent effort funded by the US Exascale Computing Project to develop production OpenACC compiler support for Clang and LLVM.  A key feature of the Clacc design is to translate OpenACC to OpenMP to build on Clang's existing OpenMP compiler and runtime support.  In this paper, we describe the Clacc goals and design.  We also describe the challenges that we have encountered so far in our prototyping efforts, and we present some early performance results.

Read Publication

Last Updated: May 28, 2020 - 4:02 pm