<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/64249>64249</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
MicroBenchmarks/XRay tests FAIL to link
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
Meinersbur
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
rorth
</td>
</tr>
</table>
<pre>
While building LLVM 17.0.0 rc1 on Solaris/amd64, two `test-suite` tests `FAIL`ed to link, breaking the `test-suite` build:
```
FAILED: MicroBenchmarks/XRay/ReturnReference/retref-bench
[...]
Undefined first referenced
symbol in file
__xray_set_handler MicroBenchmarks/XRay/ReturnReference/CMakeFiles/retref-bench.dir/retref-bench.cc.o
__xray_patch MicroBenchmarks/XRay/ReturnReference/CMakeFiles/retref-bench.dir/retref-bench.cc.o
__xray_remove_handler MicroBenchmarks/XRay/ReturnReference/CMakeFiles/retref-bench.dir/retref-bench.cc.o
__xray_unpatch MicroBenchmarks/XRay/ReturnReference/CMakeFiles/retref-bench.dir/retref-bench.cc.o
ld: fatal: symbol referencing errors
FAILED: MicroBenchmarks/XRay/FDRMode/fdrmode-bench
[...]
Undefined first referenced
symbol in file
__xray_log_flushLog MicroBenchmarks/XRay/FDRMode/CMakeFiles/fdrmode-bench.dir/fdrmode-bench.cc.o
__xray_log_init_mode MicroBenchmarks/XRay/FDRMode/CMakeFiles/fdrmode-bench.dir/fdrmode-bench.cc.o
__xray_patch MicroBenchmarks/XRay/FDRMode/CMakeFiles/fdrmode-bench.dir/fdrmode-bench.cc.o
__xray_remove_customevent_handler MicroBenchmarks/XRay/FDRMode/CMakeFiles/fdrmode-bench.dir/fdrmode-bench.cc.o
__xray_unpatch MicroBenchmarks/XRay/FDRMode/CMakeFiles/fdrmode-bench.dir/fdrmode-bench.cc.o
__xray_log_finalize MicroBenchmarks/XRay/FDRMode/CMakeFiles/fdrmode-bench.dir/fdrmode-bench.cc.o
__xray_log_select_mode MicroBenchmarks/XRay/FDRMode/CMakeFiles/fdrmode-bench.dir/fdrmode-bench.cc.o
ld: fatal: symbol referencing errors
```
This is a regression from LLVM 16 and caused by problems of the `MicroBenchmarks/XRay/CMakeLists.txt` XRay checks. The build log shows
```
-- Performing Test COMPILER_HAS_FXRAY_INSTRUMENT
-- Performing Test COMPILER_HAS_FXRAY_INSTRUMENT - Success
-- Looking for include file xray/xray_interface.h
-- Looking for include file xray/xray_interface.h - found
-- XRay tests enabled
```
- The first test obviously passed for a `test-release.sh` build: the just-built `clang` always supports the `-fxray-instrument` flag.
- The test for `xray/xray_interface.h` always passes as well: the XRay headers are always installed, irrespective whether XRay is supported on a particular target. I believe this is something that should be fixed, thus avoiding the problem in the first place.
- The cmake tests are thus at least incomplete, wrong in the worst case. They **should** check if an executable using XRay can be compiled **and** linked. This way, the hack in `CMakeLists.txt` to check for `x86 && !darwin` (which is practically guaranteed to become stale) can be avoided.
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJy8V1tv2zoS_jX0y8CCTDuy_eAHN6mxAexu4aS73SeDIkcSG4o0SMqO99cfjC45TS-nFxQOAlgXznzfzDcjDkUIurSIK3bzhnG-Q23Rh7zxjHN2czcSTaycX3nnYzXKnbqs_ltpg5A32ihtS9hu_7ODyTxJkxS8nICz8OCM8DowvhG1ymaM30I8O2BZGjHEcWh0RJalQHeBHm_W91uWpaggOjDaPpFJ7lE8EUKs8GvbFp9N1yy9Y-maZWn_396Sv7d3bLqGnZbevUErq1r4J6L0cS8ujG_2GBtv91igRyuR8Y3H6LEY57S493rzJkkSdnPX3X6wCgttUUGhfYjgB2PVvYdwqXNn4J_-tIVCG-wMDodnLy6HgPFQCasM-l_he7sTT7jRBsMX5BOl_ZePpEzcK9CjiLK6HpzH2p3w-mE29lqBttUIhYjC0EVfC0ONUB2j986HvrR-tk43d_udU8SrUL52CjtguGqFGlceCtOEauvKn6H6KoWvePc5fP3sK9UIT1sdD7ToGoA_KJI_B9T3gWxCdDWe0P5E6_859B92w5-VsNBWGP3_qyhIeAENyisUzS-2-uu96bHSAXQAAR5LjyFoZ6Hwru530gyEVSBFE1BBfoGjd7nBOoArhp3wu7G1EW11iCGJz5G2SXoBskL5FBKAx6rfuMG4EkLlzt_mOB7De_SF8zUF84ghwu2_d-_vt2_3h3-tHw6bj_v1_w737x4e9x92b989_p4VjOGhkRJDeLHfOtdu-YXzoK00jcL2awSkMeObVmptI_pCSEyq3zaEMRSuserFQZuobiBBK3IzfDK_zEybw-7rSqvB5SftmmAucBSBJCMG4mVe8WhQBExC9fnQ0gr5qQlxTE8irZZG2JLWCHMWlwChOR6dj2HQfFxQCGNtQ_RNjbZVtzCiTD4n1lIiBixLv5eyvzFaxgFEgDMaM_BqM1GhUOgDCI_DaoIWhhLDb0F7j-GIMuoTwrnCWKHvLPULd1Q0DAo4Ch-1bIzwEIUvMSYA95Cj0XhCiH0_BFdjrLp5T0QqzsYoyCnZzx1mrJoA4uS0GqbCvjdoz4ovshwNxfl5VmQtnrAXlwLqHEUgaSKVi6uPBiMSyNk7Ww4Oz44cShKwbZ4LML5mfN2R66677gJdgLCAzyibSOUDTSCWXf8JS4EQjDaoeifCDh5o4kXVQugAZ5LttsWvBHm2pObXrR1dDz3ovciA8Yxx-pko4c_a0jrGF-dKy4qSfPRCRi2FMRcoG-GFjdhN3TlKVyOQxMj4cuDcphtVMlKrqVpOl2KEq0m2TOfLGz6ZjKrVcpnl0znyWVYsZ1k2n6YiXSx4ms2X2TzNFyO94imfpvPpJF3ydDJJ1HI6l-pmqhZyscinBZulWAttEmNOdeJ8OdIhNLjKZny2HBmRown96cTiGdqX_eHEr8hmnDdlYLPUtNl58RJ1NLj69reyLwaav4Yjx6jxZlXFeAx0quAbxjeljlWTJ9LVjG_Ib_8zPnr3CWVkfNOyIa8t278CAAD__89Wa4Y">