NoT: a High-Level No-Threading Parallel Programming Method for Heterogeneous Systems

Shusen Wu,Xiaoshe Dong,Xingjun Zhang,Zhengdong Zhu
DOI: https://doi.org/10.1007/s11227-019-02749-1
IF: 3.3
2019-01-01
The Journal of Supercomputing
Abstract:Multithreading is the core of mainstream heterogeneous programming methods such as CUDA and OpenCL. However, multithreaded parallel programming requires programmers to handle low-level runtime details, making the programming process complex and error prone. This paper presents no-threading (NoT), a high-level no-threading programming method. It introduces the association structure, a new language construct, to provide a declarative runtime-free expression of different data parallelisms and avoid the use of multithreading. The NoT method designs C-like syntax for the association structure and implements a compiler and runtime system using OpenCL as an intermediate language. We demonstrate the effectiveness of our techniques with multiple benchmarks. The size of the NoT code is comparable to that of the serial code and is far less than that of the benchmark OpenCL code. The compiler generates efficient OpenCL code, yielding a performance competitive with or equivalent to that of the manually optimized benchmark OpenCL code on both a GPU platform and an MIC platform.
What problem does this paper attempt to address?