| .. _omp140: |
| |
| Could not internalize function. Some optimizations may not be possible. [OMP140] |
| ==================================================================================================================== |
| |
| This analysis remark indicates that function internalization failed for the |
| given function. Internalization occurs when a call to a function that ordinarily |
| has external visibility is replaced with a call to a copy of that function with |
| only internal visibility. This allows the compiler to make strong static |
| assertions about the context a function is called in. Without internalization |
| this analysis would always be invalidated by the possibility of someone calling |
| the function in a different context outside of the current translation unit. |
| This is necessary for optimizations like :ref:`OMP111 <omp111>` and :ref:`OMP120 |
| <omp120>`. If a function failed to be internalized it most likely has linkage |
| that cannot be copied. Internalization is currently only enabled by default for |
| OpenMP target offloading. |
| |
| Examples |
| -------- |
| |
| This will occur for any function declaration that has incompatible linkage. |
| |
| .. code-block:: c++ |
| |
| __attribute__((weak)) void setup(); |
| |
| void foo() { |
| #pragma omp target |
| { |
| setup(); |
| #pragma omp parallel |
| { |
| work(); |
| } |
| } |
| } |
| |
| .. code-block:: console |
| |
| $ clang++ -fopenmp -fopenmp-targets=nvptx64 -O1 -Rpass-analysis=openmp-opt omp140.cpp |
| omp140.cpp:1:1: remark: Could not internalize function. Some optimizations may not |
| be possible. [OMP140] |
| __attribute__((weak)) void setup() { |
| ^ |
| |
| Diagnostic Scope |
| ---------------- |
| |
| OpenMP analysis remark. |