Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / openmp / docs / index.rst
blob5d39a1c8f080bee76aaf874ced03f0b7de27746d
1 .. title:: Welcome to the documentation of OpenMP in LLVM!
3 .. note::
4    This document is a work in progress and most of the expected content is not
5    yet available. While you can expect changes, we always welcome feedback and
6    additions. Please post on the `Discourse forums (Runtimes - 
7    OpenMP) <https://discourse.llvm.org/c/runtimes/openmp/35>`__..
9 .. toctree::
10    :hidden:
11    :maxdepth: 1
13    LLVM/OpenMP Documentation <self>
16 LLVM/OpenMP Design & Overview
17 =============================
19 OpenMP impacts various parts of the LLVM project, from the frontends (`Clang
20 <https://clang.llvm.org/docs/OpenMPSupport.html>`_ and Flang), through
21 middle-end :ref:`optimizations <llvm_openmp_optimizations>`, up to the
22 multitude of available :ref:`OpenMP runtimes <openmp_runtimes>`.
24 A high-level overview of OpenMP in LLVM can be found :doc:`here <design/Overview>`.
26 .. toctree::
27    :hidden:
28    :maxdepth: 1
30    design/Overview
32 OpenACC Support
33 ===============
35 :doc:`OpenACC support <openacc/Overview>` is under development for
36 both Flang and Clang.  For this purpose, LLVM's OpenMP runtimes are
37 being extended to serve as OpenACC runtimes.  In some cases, Clang
38 supports :doc:`OpenMP extensions <openacc/OpenMPExtensions>` to make
39 the additional functionality also available in OpenMP applications.
41 .. toctree::
42    :hidden:
43    :maxdepth: 1
45    openacc/Overview
47 LLVM/OpenMP Optimizations
48 =========================
50 LLVM, since `version 11 <https://releases.llvm.org/download.html#11.0.0>`_ (12 Oct
51 2020), has an :doc:`OpenMP-Aware optimization pass <optimizations/OpenMPOpt>`
52 as well as the ability to :doc:`perform "scalar optimizations" across OpenMP region
53 boundaries <optimizations/OpenMPUnawareOptimizations>`.
55 In-depth discussion of the topic can be found :doc:`here <optimizations/Overview>`.
57 .. toctree::
58    :hidden:
59    :maxdepth: 1
61    optimizations/Overview
63 LLVM/OpenMP Optimization Remarks
64 ================================
66 LLVM has an elaborate ecosystem around `analysis and optimization remarks
67 <https://llvm.org/docs/Remarks.html>`_ issues during
68 compilation. The remarks can be enabled from the clang frontend `[1]`_ `[2]`_
69 in various formats `[3]`_ `[4]`_ to be used by tools, i.a., `opt-viewer` or
70 `llvm-opt-report` (dated).
72 The OpenMP optimizations in LLVM have been developed with remark support as a
73 priority. For a list of OpenMP specific remarks and more information on them,
74 please refer to :doc:`remarks/OptimizationRemarks`.
77 .. _`[1]`: https://clang.llvm.org/docs/UsersManual.html#options-to-emit-optimization-reports
78 .. _`[2]`: https://clang.llvm.org/docs/ClangCommandLineReference.html#diagnostic-flags
79 .. _`[3]`: https://clang.llvm.org/docs/ClangCommandLineReference.html#cmdoption-clang-foptimization-record-file
80 .. _`[4]`: https://clang.llvm.org/docs/ClangCommandLineReference.html#cmdoption-clang1-fsave-optimization-record
82 + `[1]`_ https://clang.llvm.org/docs/UsersManual.html#options-to-emit-optimization-reports
83 + `[2]`_ https://clang.llvm.org/docs/ClangCommandLineReference.html#diagnostic-flags
84 + `[3]`_ https://clang.llvm.org/docs/ClangCommandLineReference.html#cmdoption-clang-foptimization-record-file
85 + `[4]`_ https://clang.llvm.org/docs/ClangCommandLineReference.html#cmdoption-clang1-fsave-optimization-record
88 .. toctree::
89    :hidden:
90    :maxdepth: 1
92    remarks/OptimizationRemarks
94 OpenMP Command-Line Argument Reference
95 ======================================
96 In addition to the 
97 `Clang command-line argument reference <https://clang.llvm.org/docs/ClangCommandLineReference.html>`_ 
98 we also recommend the OpenMP 
99 :doc:`command-line argument reference <CommandLineArgumentReference>` 
100 page that offers a detailed overview of options specific to OpenMP. It also 
101 contains a list of OpenMP offloading related command-line arguments.
104 .. toctree::
105    :hidden:
106    :maxdepth: 1
108    CommandLineArgumentReference
110 Support, Getting Involved, and Frequently Asked Questions (FAQ)
111 ===============================================================
113 Dealing with OpenMP can be complicated. For help with the setup of an OpenMP
114 (offload) capable compiler toolchain, its usage, and common problems, consult
115 the :doc:`Support and FAQ <SupportAndFAQ>` page.
117 We also encourage everyone interested in OpenMP in LLVM to :doc:`get involved
118 <SupportAndFAQ>`.
121 .. toctree::
122    :hidden:
123    :maxdepth: 1
125    SupportAndFAQ
127 Release Notes
128 =============
130 The current (in-progress) release notes can be found :doc:`here <ReleaseNotes>` while
131 release notes for releases, starting with LLVM 12, will be available on `the
132 Download Page <https://releases.llvm.org/download.html>`_.
135 .. toctree::
136    :hidden:
137    :maxdepth: 1
139    In-Progress ReleaseNotes <ReleaseNotes>