<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/123077>123077</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
llvm-mc uses wrong ABI for RISC-V platform on Linux by default
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
directhex
</td>
</tr>
</table>
<pre>
This is a related issue to https://github.com/llvm/llvm-project/issues/115679 and possibly https://github.com/llvm/llvm-project/issues/50591. Generally, the default ABI handling is done differently in every tool, where https://reviews.llvm.org/D69383 defined the current behaviour for clang.
Roughly speaking, it is reasonable for a user to expect these two compiler invocations to act in an equivalent way:
```
$ clang -o bottles.o bottles.c
```
```
$ clang -S -o bottles.S bottles.c
$ llvm-mc --filetype=obj -o bottles.o bottles.S
```
However, they don't. Without use of the (undocumented) `-target-abi=lp64d` flag, `llvm-mc` targets a different ABI and the resulting object files cannot be linked with objects produced by `clang`/`clang++`
Per the changes in D69383 to clang/lib/Driver/ToolChains/Arch/RISCV.cpp, the logic used by clang to this day is:
```
if (Triple.getOS() == llvm::Triple::UnknownOS)
return "lp64";
else
return "lp64d";
```
i.e. use `lp64` unless a named OS is used, in which case use `lp64d`. Explicitly forcing an OS into the triple (i.e. passing `-triple riscv64-unknown-linux-gnu` to `llvm-mc`) does not result in the `clang` behaviour of defaulting to `lp64d` when calling `llvm-mc`.
As time allows, I intend to try and get a PR filed to unify `llvm-mc`'s behaviour - I wanted to document the issue first.
</pre>
<img width="1" height="1" alt="" src="http://email.email.llvm.org/o/eJykVc1u4zYQfhr6MrAgUZZsH3Rw1nUboMAu1un2TFEjiRuaVEnKit6-GMpOsun2tICBKPb8fT8zEt6rziBWrHhgxXElxtBbVzXKoQw9vqxq28zVU688KA8CHGoRsAHl_YgQLPQhDJ7lB8ZPjJ86FfqxTqS9MH7S-nr_sx6c_Y4yMH6KmZ7xU5YV5XYPwjQwWO9VredfqFakxT5L4Hc06ITWM-OfIPQIDbZi1AEOD4_QC9NoZTqC0liD0Ki2RYcm6BmUAbyimyFYqyl76tHhh4kcXhVOPqEpEus6xk_Hcp_vcuqjDDaxpxwdFYUae3FVdnTQWgdSC9MlLD2w9PDVjl2vZ_ADimdlOuqnAs3lUHhrRK0xJgkYPToiGl8GlIHqe4QwWZD2MiiNDpS5WimCssZToJCBwAgD-M-orkLTKJOYCURszsr09kkPjG-WwWBtobYhaPTJ25P8GP6_2ef3Bc4_FuAbiLJdJKzXrdIY5gFZfrT195-3Pf-37R92Inluss6kH-PbkMDfKvR2DMQT2Dbyz_huNI2V4wVNwIbxPbAyXQfhOgxrUSuWH_VQbhpWptBqEelnZXobkr5dYsnxrx6JFiK3UguHftSBvGRrsiIQLA9SGGNJeNDKPGMDkwr9LcTD4GwzSmygnqldZI4A8tPrf_yBPnfQX0h6MlQvTIeeZL3ZLVi4JZy0qsmGTkV6Tk_W6k-9UIa24uBkz_jp6-P507dEDsN9K7TtlCTK4iyLhMFCoD1vxAzK_9QtAACqJX6fnBo0Jh2Gz2fGd5Hi_MjyY1SakvPDErM8_2WejZ0MBe-pkMMwOgOMcxKCcc7yh1sD1B5vj_AhrnkN_OAOlWASHUAqUsEyhdFo9KSgERds4POZ1osgx2UzMPVK9iCFx_eZ5IkEfnsZtJKK7kJrnSSdhYklTKQJIURwREXsPdAhNd3is-Unp7y8lpv1uEBfa2XGl3Vnxugv-6PhiMDGogeyz2IumjG6-c0p7y6Kbe-nTS3avZufTpcBKbS-jfTW53Z_Dh6CuiAIre3kiZBHgobkbgvBzdHoHQYQ8OVrNHf8ZTSqnT9OvvXv5lrDI0yC1o7i70sYgSzvjFY5H5JVU-XNPt-LFVbZNi_3xXa3y1d91bZlVhebfVoWm73EumwKLnm2bbJabMuSr1TFU16kWVZkZbZL82SDRSHqPUosN20pBNukeBFKvx7pVWxcZTxPt9uVFjVqH993nBuclrHIWMVx5aoIrB47zzapVj683fpVUEFjdb9ko0cPk7Omi4eBjjWt2fobDFqE1roLWAN_kui0YzexVqPT1S-8MxcM14r_GwAA___kWXwo">