Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / openmp / docs / remarks / OMP121.rst
blob88561b8a1fe1afd67d76337e283692be94d9d1aa
1 .. _omp121:
3 Value has potential side effects preventing SPMD-mode execution. Add `__attribute__((assume(\"ompx_spmd_amenable\")))` to the called function to override. [OMP121]
4 ===================================================================================================================================================================
6 This analysis remarks indicates that a potential side-effect that cannot be
7 guarded prevents the target region from executing in SPMD-mode. SPMD-mode
8 requires that each thread is active inside the region. Any instruction that
9 cannot be either recomputed by each thread independently or guarded and executed
10 by a single thread prevents the region from executing in SPMD-mode.
12 This remark will attempt to print out the instructions preventing the region
13 from being executed in SPMD-mode. Calls to functions outside the current
14 translation unit will prevent this transformation from occurring as well, but
15 can be overridden using an assumption stating that it contains no calls that
16 prevent SPMD execution.
18 Examples
19 --------
21 Calls to functions outside the current translation unit may contain instructions
22 or operations that cannot be executed in SPMD-mode.
24 .. code-block:: c++
26   extern int work();
28   void use(int x);
30   void foo() {
31   #pragma omp target teams
32     {
33       int x = work();
34   #pragma omp parallel
35         use(x);
37     }
38   }
41 .. code-block:: console
43    $ clang++ -fopenmp -fopenmp-targets=nvptx64 -O2 -Rpass-analysis=openmp-opt omp121.cpp
44    omp121.cpp:8:13: remark: Value has potential side effects preventing SPMD-mode
45    execution.  Add `__attribute__((assume("ompx_spmd_amenable")))` to the called function
46    to override. [OMP121]
47    int x = work();
48             ^
50 As the remark suggests, the problem is caused by the unknown call to the
51 external function ``work``. This can be overridden by asserting that it does not
52 contain any code that prevents SPMD-mode execution.
54 .. code-block:: c++
56   __attribute__((assume("ompx_spmd_amenable"))) extern int work();
58   void use(int x);
60   void foo() {
61   #pragma omp target teams
62     {
63       int x = work();
64   #pragma omp parallel
65         use(x);
67     }
68   }
70 .. code-block:: console
72    $ clang++ -fopenmp -fopenmp-targets=nvptx64 -O2 -Rpass=openmp-opt omp121.cpp
73    omp121.cpp:6:1: remark: Transformed generic-mode kernel to SPMD-mode. [OMP120]
74    #pragma omp target teams
75    ^
77 Diagnostic Scope
78 ----------------
80 OpenMP target offloading analysis remark.