<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/57581>57581</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
[RISCV][Runtime] Error when build libc and compiler-rt for cross compler
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
Incarnation-p-lee
</td>
</tr>
</table>
<pre>
# Table of contents
- [Purpose](#purpose)
- [Environment of the Building System](#environment-of-the-building-system)
- [Build Options](#build-options)
- [Build with GNU Tool Chain](#build-with-gnu-tool-chain)
- [The `libc` error](#the-libc-error)
- [The `compiler-rt` error](#the-compiler-rt-error)
- [Questions](#questions)
- [Reference](#reference)
- [Hello World Source Code for Cross Compile Testing](#hello-world-source-code-for-cross-compile-testing)
## Purpose
Recently I would like to build the cross clang compiler target `RISCV`. I am trying to build the cross-clang compiler, as well as the related runtime libraries, headers, and the linker of the llvm project.
## Environment of the Building System
* X86_64 ubuntu `22.04`.
* Clang version is `14.0.0`.
* Pre-installed `riscv64-linux-gnu-gcc` version is `11.0`.
## Build Options
### Build with GNU Tool Chain
For the first approach, it works well and I can compile the hello world c source. Here is the CMake options for the first approach.
```shell
cmake -G Ninja -DCMAKE_BUILD_TYPE="Release" \
-DCMAKE_INSTALL_PREFIX=../__INSTALL__ \
-DCMAKE_C_COMPILER=clang -DCMAKE_CXX_COMPILER=clang++ \
-DCMAKE_BUILD_TYPE=Release \
-DLLVM_ENABLE_PROJECTS="clang;clang-tools-extra;lld" \
-DLLVM_ENABLE_RUNTIMES="libcxx;libcxxabi;libunwind;libc;compiler-rt" \
-DLLVM_TARGETS_TO_BUILD="RISCV" \
-DLLVM_DEFAULT_TARGET_TRIPLE="riscv64-linux-gnu" \
../llvm
```
Unfortunately, the `libc` and the `compiler-rt` cannot be built out successfully with the below error. Excluded the `libc` and `compiler-rt` are able to build successfully, but we may need to involve the gnu headers and related libraries.
### The `libc` error
```
CMake Error at /home/pli/repos/riscv/0000/llvm-project/libc/cmake/modules/LLVMLibCCheckCpuFeatures.cmake:83 (message):
Failed to compile: Change Dir:
/home/pli/repos/riscv/0000/llvm-project/__BUILD_ALL_WITH_COMILER_RT/runtimes/runtimes-bins/libc/check_/CMakeFiles/CMakeTmp
Run Build Command(s):/usr/local/bin/ninja cmTC_00ed2 && [1/2] Building CXX
object CMakeFiles/cmTC_00ed2.dir/check_cpu_features.cpp.o
FAILED: CMakeFiles/cmTC_00ed2.dir/check_cpu_features.cpp.o
/home/pli/repos/riscv/0000/llvm-project/__BUILD_ALL_WITH_COMILER_RT/./bin/clang++
--target=riscv64-linux-gnu -fPIC -fno-semantic-interposition
-fvisibility-inlines-hidden -Werror=date-time
-Werror=unguarded-availability-new -Wall -Wextra -Wno-unused-parameter
-Wwrite-strings -Wcast-qual -Wmissing-field-initializers
-Wimplicit-fallthrough -Wcovered-switch-default -Wno-noexcept-type
-Wnon-virtual-dtor -Wdelete-non-virtual-dtor -Wsuggest-override
-Wno-comment -Wstring-conversion -Wmisleading-indentation
-Wctad-maybe-unsupported -fdiagnostics-color -ffunction-sections
-fdata-sections -march=native -std=gnu++17 -MD -MT
CMakeFiles/cmTC_00ed2.dir/check_cpu_features.cpp.o -MF
CMakeFiles/cmTC_00ed2.dir/check_cpu_features.cpp.o.d -o
CMakeFiles/cmTC_00ed2.dir/check_cpu_features.cpp.o -c
/home/pli/repos/riscv/0000/llvm-project/__BUILD_ALL_WITH_COMILER_RT/runtimes/runtimes-bins/libc/cpu_features/check_cpu_features.cpp
clang-16: error: invalid arch name 'native', string must begin with
rv32{i,e,g} or rv64{i,g}
ninja: build stopped: subcommand failed.
Call Stack (most recent call first):
/home/pli/repos/riscv/0000/llvm-project/libc/CMakeLists.txt:108 (include)
```
### The `compiler-rt` error
```
FAILED: projects/compiler-rt/lib/builtins/CMakeFiles/clang_rt.builtins-riscv64.dir/riscv/save.S.o
/usr/bin/clang -DVISIBILITY_HIDDEN -D_GNU_SOURCE -D__STDC_CONSTANT_MACROS -D__STDC_FORMAT_MACROS -D__STDC_LIMIT_MACROS -I/home/pli/repos/riscv/0000/llvm-project/__BUILD_ALL_WITH_COMILER_RT/projects/compiler-rt/lib/builtins -I/home/pli/repos/riscv/0000/llvm-project/compiler-rt/lib/builtins -I/home/pli/repos/riscv/0000/llvm-project/__BUILD_ALL_WITH_COMILER_RT/include -I/home/pli/repos/riscv/0000/llvm-project/llvm/include -fPIC -O3 -DNDEBUG -fno-lto -std=c11 -MD -MT projects/compiler-rt/lib/builtins/CMakeFiles/clang_rt.builtins-riscv64.dir/riscv/save.S.o -MF projects/compiler-rt/lib/builtins/CMakeFiles/clang_rt.builtins-riscv64.dir/riscv/save.S.o.d -o projects/compiler-rt/lib/builtins/CMakeFiles/clang_rt.builtins-riscv64.dir/riscv/save.S.o -c /home/pli/repos/riscv/0000/llvm-project/compiler-rt/lib/builtins/riscv/save.S
/home/pli/repos/riscv/0000/llvm-project/compiler-rt/lib/builtins/riscv/save.S:185:3: error: "xlen must be 32 or 64 for save-restore implementation
# error "xlen must be 32 or 64 for save-restore implementation
```
## Questions
* Is there anything/steps missing to make it work?
* What is the support status of the RISCV `libc` and `compiler-rt` if it doesn't work?
* If there is a gap, what is the plan, and is there anything I can do to make it happen?
## Reference
### Hello World Source Code for Cross Compile Testing
```c
#include <stdio.h>
int main()
{
printf("Hello, llvm for riscv!\n");
return 0;
}
```
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzFWFt34jgS_jXkRUc-YAJJHvJADHR7l1wWSKfniSNsGTRtJI8kh2R__VbJF2wgOzPdp3v6pG0j1VWq-qqktYrfbzt-nyzZOuVEJSRS0nJpTac77nRHxZOSzuDuKdeZMrwzGHf8a2DJyt_-TYNoIl-FVnIHElCY3XJyl4s0FnJDFu_G8l3Nzw-kVCUUSOm6JKWmIG2JdnLIY2aFkqaW4lioKkcrBkIaLHtht-TTwzNZKpWSYMuEPGJHCrqRObVAQSNHcSRqCZ50ht1UrCN4Ea610rUUtB1naDF8njVSu0ykXFNtz0toEBwJcmL-k3PT9v2PeqRFOOcJ11xGh63S9ciRaZ95miryojQs00LlOuIkUDEnidIk0MoY-OmMIktUJTe1yC1y0j1yUuM4wf6YU-CkEXJW7lBbclaqy6ffx7Arg4o0p-Y8gphI30lI9ioHy1LxjROriNssF1NOA4lSBmFVLRuxTG-4xaWeh4vgC7w9EMF2xOp3jL9TCbQtoeMHhBmyB9fwjWSap8zymOhcWrHjYMpaMy24QdotZzHX7pPJQmwq5DcwpQz9NH3dkUyr33lkvTPe_4VsaTGNyNfr4Wp4SfI12JOjq77vdS_R1QNN4Jx6BcsgNogwSNa79Lpet033pDkV0liWpuAhzGlhotfhJYSyzN9cPmwiF-1HsnotSU2H2jnamDlMnstGRziFmMMVSIQ2lrAM1o1FW1xcYSEQ9LdqZ2CpQxIxWe2b43LxSFw8kogUEemRzxD2aDVSBPcMwqhEChfhp9raPg27xZ9B4cVYtEMh9BN5EPJ3Rug4uB_9e7K6ew5n49Xyt6dJpw8J4s95yhliow9ZFlQpR2r68GGxHM1mq6f5ZBp-BR7P6_jTVT2-Os8WrILH-6dwNpkDSxG79dTXryeTHf8O_s6LallcmntMOZt9uV9NHkZ3swlY-vivSbBcFP4V4vt37u1Q01D-ZjWDsTSNz_jdlDV_fliG95NSFgLn2xsyug-2FsV3LvdCxuU46mrg5wfyl6P5p8lysVo-Fv6Vm-HQ4AOW8WQ6ep4tS9bVch4-zcpNPEmHExlu1zDJjwKmGUXPEkLN5hJgJH3HaLbtSlIhx2mFgBCXypI1d7AFCJFbYvIo4sYkeQr46FIJedc8Vfuionhk8haleczjc4pOlTBIEFf6a3RsqkB716B2z8mOvRPJUawiQr6q9LVIPFiXCgidigoxa6T0jnHgbCk9l3fFzyJvJ0hFGMC7P92qHaTWNEsFPDWHAoJv3C14d-FfuSu0hF78icr8qUtfeO9UnKcI4lMMgplYB8GWR9-CLJ9yZnMNVhek_dF1H1Re72BF2MbVz_6oCoApE2mxIOWiwhwimtxwMha6Qfl9Rq_KLEVEeAmXnzHBMb9X8yXyFiXJND7pWmAzUHuLPq3gwy3hVBQeux_LXdZa8pMnIfNclpANPcAOthaWwZQL4E9zo1GRilgK7zU2TFPpMDHaLYNVt8tjSBZ_CH_YaPRg2ofm4VDfALAqTWqNDpOWlQcpXix07UyU5auk3qIs81Tb6OkIFmjs9uGHpf3MzfPqRWsgdd2a0aKVARg6wSBCk6cwgKdU1HDYFisiqOKWYx8lsLbVUpJXYcRapMK-AwVIgADZijjmktCXIuv64xiSlWLw1Gz1VC43OdOAJJS9QqSzUpTkeyCCpgFJEfPhDcbkMjdAmjHNdhzMOcjbawE6jNWw7QZ-R8xY-kfOUMBOGIMNfyI4NJJCggcsFf_FrqrmFztY90hYmoBSu9Uq32xRjIK2BDQagMFoS2OesBxQ0hkjFX-LeGapfc8ankklKXRcFnTT2AKe0JcYSh9Yd2bG5JsNtK4U1WgRt8Rgc-u6NiBzfsGArLok5xUUVHeSgRIGdKy1MS-RZTEFQF1zWDaTZxlUCAASmsSCbaSCfjnC_jlFO5IklxGyw3ZHjb4KNxg2j9XDBCRqaJj6Y6g1AtAZlhzK59gVLgyv3hWh92P4v6wkfF-OgITpj0nwwFf1o0ZE_zC4Nkz60M5zcFL0TL0hglSZaiOsqBD3McEdJBIyCLy6KvYRPrAMF3FGdrnBlmAjpCv_lVD92vc7V3fgfgAMwaZzNSYQPRqwoxzGobYhDq5ReVn3rcoyHuOAyddRgfkkcTXO-6hMBIgDC8uib65KQuhCA4DHN-heYMZ11-2i-UP128XKTBhrPPsG-Djqda9RsZCu5zmcMc91YicdyNkT-ceNyKG2lHa5fW92pWgmAju2a0WwtIMbd36lrVcR0BLey1ivlsCwV-4t6mJUFdtGvYDu9Uu4CO_CWbj8bfU5HI8nDzC2gnPVavH4PA8m-Gu1WI7xyICHiofl6n4UzB8Xh4np4_x-dDo8C-_Dw2j4M7LrL67fd2v_KUL_v0tlBH63dHeKaIgpqvxjH_blYTy5e_5UlPwUms0S16Ner8LzXxWQiPy_SperEb_Oseg7gelPrGorqhP6pysCZLwewLPfqjJwgH1Lof0riwjp-1gkhpfuNgQ5KdQt6H44wZ6L79qdCyKnE_Wjcj4GZ3K45Dy6-ArdJQ4eVuW73br7xKmxPDOkbCHxGOYuZ8rbok5_euB-2cLJsbwHKvstqHdQp0117-YuCf78uCwSlB8rbgCLr85oCpPSTtDGyIZlWLv3DfUZhGZ1YyiOnSovtmLV9GbLoC7Lg5bmeh3ues8Wur9_v3uu_EW12AqeOv0AQEgoD9rNSZMHTiJgNxaq60MxvrqrSG4yaGJs4mZ9ZxwuhbsmRZPKIO51BgFI8F3jcODVHPoqSbqHsbqjORtR7nnBb3vDoX95dXXZ61_Et_34pn_DLqywKb_Fy3J3OTQY42fR6OEptbht2G8hxovmCKPCbVkjHpzJ5U20wjjXF7lOb7fWZqY4JMPfBpq0fO0BwQHkjzIb4jd3qDW4Glz3Lra3l4MkjrsD3x9cx_CM1wnr3Qz52ueRf9ljwws4i_HUoPmwSngecyJwxQbjC3Hrd32_e9Md9ga94cD3-v5V94qDrGSQ9JJe3LnswsFRpB7a4Sm9udC3zqR1vjEwmbr-qp5kkF4byd1qoXyW263St6GMmJYurWlGU84vnBG3zon_AfoyP7E">