<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 - Cannot build builtins on ARMv6 (unsupported instructions)"
   href="https://bugs.llvm.org/show_bug.cgi?id=39906">39906</a>
          </td>
        </tr>

        <tr>
          <th>Summary</th>
          <td>Cannot build builtins on ARMv6 (unsupported instructions)
          </td>
        </tr>

        <tr>
          <th>Product</th>
          <td>compiler-rt
          </td>
        </tr>

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

        <tr>
          <th>Hardware</th>
          <td>Other
          </td>
        </tr>

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

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

        <tr>
          <th>Severity</th>
          <td>normal
          </td>
        </tr>

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

        <tr>
          <th>Component</th>
          <td>builtins
          </td>
        </tr>

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

        <tr>
          <th>Reporter</th>
          <td>lizardm4@gmail.com
          </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=21199" name="attach_21199" title="Build log for gcc and clang and Dockerfile">attachment 21199</a> <a href="attachment.cgi?id=21199&action=edit" title="Build log for gcc and clang and Dockerfile">[details]</a></span>
Build log for gcc and clang and Dockerfile

Compiler-rt cannot be built on ARMv6 architectures such as ARM1176JZF-S, there
are some memory barrier instructions in
`compiler-rt/lib/builtins/arm/sync-ops.h` that are not supported (namely
`dmb`).
This means it can't be truly build for Raspbian or on a Raspberry Pi, but the
error occurs also when trying to cross compile with `-march=armv6`. Indeed the
library `libclang_rt.builtins-armhf.a` is completely missing from Raspbian
(package `libclang-common-3.8-dev`).
I also found that the problem has already been mentioned in the llvm-dev
mailing list at <a href="http://lists.llvm.org/pipermail/llvm-dev/2016-May/099780.html">http://lists.llvm.org/pipermail/llvm-dev/2016-May/099780.html</a>.

I'm attaching the logfile of the errors when building
`compiler-rt/lib/builtins/arm/sync_fetch_and_add_4.S` on a Raspberry Pi with
Raspbian Stretch (kernel 4.14.79+) both with gcc (Raspbian
6.3.0-18+rpi1+deb9u1) 6.3.0 20170516 and clang (version 3.8.1-24+rpi1
tags/RELEASE_381/final). I am also attaching a Dockerfile which tries to
cross-compile compiler-rt for armv6, and also triggers the same error.


On the ARM1176JZF-S with Raspbian, I cloned the release 7.0 of llvm and
compiler-rt, and then ran `cmake` with no extra define. I ignored the errors
from CMake and I then ran `make builtins --trace` to extract the command line
used to build `sync_fetch_and_add_4.S`. The command line computed by CMake for
that file wrongly specified `-march=armv7-a`:

/usr/bin/cc  -DVISIBILITY_HIDDEN -D_DEBUG -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE
-D_LARGEFILE_SOURCE -D__STDC_CONSTANT_MACROS -D__STDC_FORMAT_MACROS
-D__STDC_LIMIT_MACROS -I/home/pi/build/projects/compiler-rt/lib/builtins
-I/home/pi/llvm/projects/compiler-rt/lib/builtins -I/home/pi/build/include
-I/home/pi/llvm/include  -fPIC -g    -march=armv7-a -mfloat-abi=hard -fno-lto
-std=c11 -fomit-frame-pointer -DCOMPILER_RT_ARMHF_TARGET -o
CMakeFiles/clang_rt.builtins-armhf.dir/arm/sync_fetch_and_add_4.S.o -c
/home/pi/llvm/projects/compiler-rt/lib/builtins/arm/sync_fetch_and_add_4.S

When crosscompiling, I had manually specified `-march=armv6`, and that
triggered the error. When replacing the architecture on the command line, I
observed the same error on the real hardware. The command line specified above
is sufficient to reproduce.
It seems the architecture is not set correctly at
`compiler-rt/cmake/base-config-ix.cmake:201` by using `test_target_arch` from
`compiler-rt/cmake/Modules/CompilerRTUtils.cmake`.


I tried to build all the targets in the Makefiles of compiler-rt in Docker to
see whether the issue is limited to that instruction, and (at least with clang)
it seems to be the case, all the other sources compiled correctly, failing only
at linking because of the missing `sync_fetch_*.S.o`.</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>