<html>
    <head>
      <base href="https://bugs.llvm.org/">
    </head>
    <body><table border="1" cellspacing="0" cellpadding="8">
        <tr>
          <th>Bug ID</th>
          <td><a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - libarcher does not work in the libomp-10-dev package"
   href="https://bugs.llvm.org/show_bug.cgi?id=45945">45945</a>
          </td>
        </tr>

        <tr>
          <th>Summary</th>
          <td>libarcher does not work in the libomp-10-dev package
          </td>
        </tr>

        <tr>
          <th>Product</th>
          <td>Packaging
          </td>
        </tr>

        <tr>
          <th>Version</th>
          <td>unspecified
          </td>
        </tr>

        <tr>
          <th>Hardware</th>
          <td>PC
          </td>
        </tr>

        <tr>
          <th>OS</th>
          <td>Linux
          </td>
        </tr>

        <tr>
          <th>Status</th>
          <td>NEW
          </td>
        </tr>

        <tr>
          <th>Severity</th>
          <td>enhancement
          </td>
        </tr>

        <tr>
          <th>Priority</th>
          <td>P
          </td>
        </tr>

        <tr>
          <th>Component</th>
          <td>deb packages
          </td>
        </tr>

        <tr>
          <th>Assignee</th>
          <td>unassignedbugs@nondot.org
          </td>
        </tr>

        <tr>
          <th>Reporter</th>
          <td>protze@itc.rwth-aachen.de
          </td>
        </tr>

        <tr>
          <th>CC</th>
          <td>llvm-bugs@lists.llvm.org
          </td>
        </tr></table>
      <p>
        <div>
        <pre>Created <span class=""><a href="attachment.cgi?id=23494" name="attach_23494" title="Example OpenMP code with no data race, but false positive report in absense of Archer">attachment 23494</a> <a href="attachment.cgi?id=23494&action=edit" title="Example OpenMP code with no data race, but false positive report in absense of Archer">[details]</a></span>
Example OpenMP code with no data race, but false positive report in absense of
Archer

The idea of Archer is to complement ThreadSanitizer and provide the
synchronization semantics for OpenMP. In a vanilla build of LLVM with openmp,
libarcher is loaded by the OpenMP runtime (libomp.so) automatically and checks
whether the TSan library is present in the execution:

$ export ARCHER_OPTIONS=verbose=1
$ clang -fopenmp -fsanitize=thread red-norace.c -g
$ OMP_NUM_THREADS=2 ./a.out
Archer detected OpenMP application with TSan, supplying OpenMP synchronization
semantics
Sum: 4999950000

Using clang-10 from the package, there are several issues. First, the archer
library is not found as the library is not in the dl search path (as also
mentioned in <a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - libraries in libomp-*-dev package not in LD_LIBRARY_PATH"
   href="show_bug.cgi?id=45909">bug 45909</a>)
$ clang-10 -fopenmp -fsanitize=thread red-norace.c -g
$ OMP_NUM_THREADS=2 ./a.out
... WARNING: ThreadSanitizer: data race ...

Creating a link in /lib/x86_64-linux-gnu should help for this.

The next issue (after I added the link):
$ OMP_NUM_THREADS=2 ./a.out
Archer detected OpenMP application without TSan stopping operation
... WARNING: ThreadSanitizer: data race ...

I could not figure out, why the archer library does not use the exported
dynamic symbols from the tsan runtime, which is statically linked into the
application:

$ readelf --dyn-syms a.out | grep RunningOnValgrind
   529: 000000000048f6f0    18 FUNC    GLOBAL DEFAULT   13 RunningOnValgrind
$ readelf --dyn-syms /usr/lib/llvm-10/lib/libarcher.so | grep RunningOnValgrind
    61: 0000000000002770    10 FUNC    WEAK   DEFAULT   12 RunningOnValgrind
$ readelf --dyn-syms /home/.../clang/10.0/lib/libarcher.so | grep
RunningOnValgrind
    64: 0000000000002590    10 FUNC    WEAK   DEFAULT   12 RunningOnValgrind

I can successfully use clang-10 with my vanilla build of libarcher. So, it
seems like there is something funny going on with libarcher from the deb
package.

Finally, I'm not sure why the library should not be installed if compiler and
OpenMP runtime are installed. I can understand that developers packages are not
installed by default, but a compiler is typically installed by developers?</pre>
        </div>
      </p>


      <hr>
      <span>You are receiving this mail because:</span>

      <ul>
          <li>You are on the CC list for the bug.</li>
      </ul>
    </body>
</html>