.. _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.