Show Your Support: This site is primarily supported by advertisements. Ads are what have allowed this site to be maintained on a daily basis for the past 18+ years. We do our best to ensure only clean, relevant ads are shown, when any nasty ads are detected, we work to remove them ASAP. If you would like to view the site without ads while still supporting our work, please consider our ad-free Phoronix Premium.
OpenMP May Finally Come To LLVM/Clang
While LLVM/Clang can build key pieces of software like Qt, the Linux kernel, LibreOffice, and much of the FreeBSD base, one shortcoming has been the lack of OpenMP support by this compiler.
OpenMP, the Open Multi-Processing API that's used by a number of programs for shared-memory multi-threaded programming in C/C++ (and Fortran too), hasn't been supported by LLVM. OpenMP is used by programs like GraphicsMagick and several of the benchmarks we commonly run at Phoronix as it's very efficient and effective for multi-process programming. OpenMP has been supported by GCC going back to their 4.3 release and is also handled by Intel's C Compiler and Sun Studio too.
From this ongoing discussion on the LLVM developers' mailing list since earlier this month (and continued in this thread), it looks like OpenMP support within LLVM/Clang may finally become actively worked on. Currently it's being discussed about handling LLVM-IR with OpenMP extensions.
One item brought up in the discussion that might be of some interest to Phoronix reader is the ROSE Compiler. ROSE is a compiler infrastructure that allows source-to-source translation of C, C++, and Fortran. OpenMP is also handled here as well. ROSE can also be used for building custom code analyzers and optimizers. Those wanting to find out more about that work can visit ROSECompiler.org.
There's no timeline for when we might see working OpenMP support in LLVM, but it would be nice for the next LLVM 3.1 release, which would allow for more multi-threaded applications to work well under LLVM/Clang and also improve some of the benchmark results.