Pure Functions in C: A Small Keyword for AutomaticParallelization
Erscheinungsdatum
2020-05-30
Datum der Freigabe
2025-10-30
Export Metadaten
Wissenschaftlicher Artikel Zweitveröffentlichung

Zusammenfassung
The need for parallel task execution has been steadily growing in recent years since manufacturers mainly improve processor performance by increasing the number of installed cores instead of scaling the processor’s frequency. To make use of this potential, an essential technique to increase the parallelism of a program is to parallelize loops. Several automatic loop nest parallelizers have been developed in the past such as PluTo. The main restriction of these tools is that the loops must be statically analyzable which, among other things, disallows function calls within the loops. In this article, we present a seemingly simple extension to the C programming language which marks functions without side-effects. These functions can then basically beignored when the automatic parallelizer checks the parallelizability of loops. We integrated the approach into the GCC compiler toolchain and evaluated it by running several real-world applications. Our experiments show that the C extension helps to identify additional parallelization opportunities and, thus, to significantly increase the performance of applications.
Schlagworte
Parallel computing
Programming
Compiler
Programming
Compiler
Fachgebiete (DDC)
000 Informatik, Wissen & Systeme
Identifikator
Erschienen in
International Journal of Parallel Programming. Spinger. 49, 1, S. 1- 24. DOI: 10.1007/s10766-020-00660-4
Umfang
S. 1- 24
Förderinformation
Gefördert aus dem Publikationsfonds der Hochschule Fulda
Einrichtung
Fachbereich Angewandte Informatik
Link zur Veröffentlichung
Sammlungen

