<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/54225>54225</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
LLVM instrumented with BOLT segfaults
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
Kobzol
</td>
</tr>
</table>
<pre>
Hi! I'm trying to use BOLT on LLVM itself to try to speed up the `rustc` compiler (https://github.com/rust-lang/rust/pull/94381).
When I instrument the LLVM library (built with `LLVM_BUILD_LLVM_DYLIB=ON`) and the `rustc` compiler later uses that instrumented library, it sometimes segfaults (https://github.com/rust-lang-ci/rust/runs/5425308791?check_suite_focus=true).
This is the output I get when instrumenting BOLT:
<details>
<summary>BOLT log</summary>
```
BOLT-WARNING: debug info will be stripped from the binary. Use -update-debug-sections to keep it.
BOLT-INFO: shared object or position-independent executable detected
BOLT-INFO: Target architecture: x86_64
BOLT-INFO: BOLT version: <unknown>
BOLT-INFO: first alloc address is 0x0
BOLT-INFO: creating new program header table at address 0x5a00000, offset 0x5a00000
BOLT-INFO: enabling relocation mode
BOLT-INFO: forcing -jump-tables=move for instrumentation
BOLT-INFO: enabling -align-macro-fusion=all since no profile was specified
BOLT-INFO: enabling lite mode
BOLT-WARNING: Failed to analyze 5229 relocations
BOLT-WARNING: Ignored 0 functions due to cold fragments.
BOLT-WARNING: 19 collisions detected while hashing binary objects. Use -v=1 to see the list.
BOLT-INSTRUMENTER: Number of indirect call site descriptors: 68972
BOLT-INSTRUMENTER: Number of indirect call target descriptors: 74099
BOLT-INSTRUMENTER: Number of function descriptors: 74099
BOLT-INSTRUMENTER: Number of branch counters: 1523333
BOLT-INSTRUMENTER: Number of ST leaf node counters: 602638
BOLT-INSTRUMENTER: Number of direct call counters: 4969
BOLT-INSTRUMENTER: Total number of counters: 2130940
BOLT-INSTRUMENTER: Total size of counters: 17047520 bytes (static alloc memory)
BOLT-INSTRUMENTER: Total size of string table emitted: 6995854 bytes in file
BOLT-INSTRUMENTER: Total size of descriptors: 128931880 bytes in file
BOLT-INSTRUMENTER: Profile will be saved to file /tmp/prof.fdata
BOLT-INFO: 0 out of 74859 functions in the binary (0.0%) have non-empty execution profile
BOLT-INFO: the input contains 15962 (dynamic count : 0) opportunities for macro-fusion optimization that are going to be fixed
BOLT-INFO: 4948511 instructions were shortened
BOLT-INFO: removed 10459 empty blocks
BOLT-INFO: merged 1 duplicate CFG edge
BOLT-INFO: removed 216 'repz' prefixes with estimated execution count of 0 times.
BOLT-INFO: UCE removed 65330 blocks and 4489397 bytes of code.
BOLT-INFO: SCTC: patched 0 tail calls (0 forward) tail calls (0 backward) from a total of 0 while removing 0 double jumps and removing 0 basic blocks totalling 0 bytes of code. CTCs total execution count is 0 and the number of times CTCs are taken is 0.
BOLT-INFO: output linked against instrumentation runtime library, lib entry point is 0xede32d0
BOLT-INFO: clear procedure is 0xede13a0
```
</details>
Is there something that looks out of place?
For instrumentation I use simply `llvm-bolt -instrument <LLVM lib> -o ...`. The LLVM lib is built with `-Wl,-q`. BOLT itself is built with LLVM version 14.0.0-rc1.
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJydV1tz2zYT_TXyC4YaXiXxQQ-JL62nrtNJnC_TJw9ILiXUIMESoC_59d9ZkLZkh0099XhEiVjs5ezZxaIw1dP2V7WII3G5iNeNcP2TanfCGTFYEh8_Xd0I04qrq__9LpSzpGteghA_bEdUiaETbk9isQr7wboST1GaplOaerGIN3vnOrtIPiziC_zvlNsPxRIC-MHygZbtbvqORzdojUeeJptoEefLRXi2CD-Mn9_21IpLoVrr-qGh1nm73jWtil7CKdgrBqWdeIAddolXbz9-vbw6u_Vfz_68uvy4SM4-XWMRBoRsq392X0uHTwBhISPdkWnEPdlcxKdARljTkFMNJC3tajloZ98bfVCqAwD90Fo8sjTOknCzzqNFclHuqby7tYNydFubcoDCM_hBbwG62SsrlPXxmMF1gwNcOwIajNzBeU4wZ5b9GrcnpxU5qTQ0n7-8skPTcIDJuaeBNju8hG-H98fGGc_x3__kLcG3D5-vL69_gR1RUTHs4ENtkButRUEC7qiuA5J1bxrvdKFaKF6Kr6BeMHQV4A_8xsBS6ZRpLdPujqgD5MsjQ5fXF5_Yit3LHgpN8RfkhelFZ6zijYFqK-oIH6ANPVI5OFloglsOklTN6LqRPWMn-3KvWGjoiV8_bla3q3RG3oN0T72FOf4NsIb2rjUP7QtSr-Rr1Vuo19qUQlZVT9YnL3wMZ4TLnqTPW0sPouvNrpeN2JOswM8xEtDzWUv4mMmQ_5ibpq4twji8-1E5tdDAynuCM5LxEo2paM5p05csGfw1NF3gLTMbG3NPvHZEMq_mZ8YCqdWuDRpZ9iaohxG2M-AhrGpLEq3hQGsUoniQlptNqWo1m6oXnRqZeuv6EQkvQHHQAxySrdRP30lkMXrAIWw7v-9y1xrmVSjqoZ2IWA3EikqjmcByxzHb5fz-KGc5rey4c-IcypKD20u7Z99H8k_ctVMR3AOSyPdaIl8iUPKG-V9uPn_9_fz65vwzm7oemgKcMDVSUamey6AcMXXMdlui5pzpuSeJ1SZfx_9Blxsr4422dRrm-bu0PYP43zWg87blHqAOaMXj5iiLE_y9a_sXdDOSNShW0SslqzBeJZt36TgG5FhFmq9-FsONcVKL9kXN8dY4SsI8Df91t1Vg7pu90TpM11kciuLJkT96LJdgOTWYhhrDZ9W_u_asnLszDwK-uVCjHHdJhijPs02WTnZUK7hC3631TcajeJMn0WYTvlvdH88t4fkQkfdjRfu3OJ1c0_EcAbFljQNEzrSLkE9H9madbrL8qKZh_nAMMYbhEj004zlhDzvgSxtQ07mn6QhhDk89asYMq1Itn8KlQT9EawRJ81XMiqunVjbIjk-h8E6xFdN1pndDizMLaHBDPW6PWMaIob6PHdpPJDjuxM5MExvgqNXjbIdMc4QaRVN_nsJ9IOy2e1ikdnZXT9zYKxGFKXAaIy9Apzs7I9wQugJk0Rk7rdBPSZxe_CKo2s2B86w6jlbAY91T9x0PoEkcgh0HOLKIV3KrPOA9IobkhcLPW3NjwNfT8xcDqyxJwslrP-2lKTiXryfG-TKqaE7Ll9ObU3520mEC4-7PI5KveF9gISfoQfYVZ-7tUiHLu-c1P99IZIgrwXs-dn7vIucuFJUZuM74VB29PForpAVTpgi8Ej0tvIpAwN1p_Qe4eK54GXUPzWccWP0-JpKTdzwnQnYOjmmihO07gCF3TGj39sAXmF9Z6_F0jK84ofnO0IGpozNgKSVxNTvqoDX3XFYlVZi5XsSjRIazo-Y4lf4wwPrPSz8NM815PvfnrK8bbQzAnNpAp2WJ2e7ieOPFj8MMhmm-E1nVdPqJLwxa3zdBYXDdCI4uJXDn-U4CZ0RgxHK5hPRS3BxdVzis11eV4BtuPqfB317UD5PTheu1pFcwjZkiSpdoUUFfRsuTaptUILY8ccpp2o5XtuMLi9_uFb9cUU6GXm9_ckfhCKdHgIzwZIKfytqBpltKnJ3st7JYZ5uU0GFWmazyTVVTWFEebdJVnNV1eKJlQdpuF9nHRRzzCOtV4PsiOztR2ziM4zAJszCPV2myLMM0lElY1xInWpStF2lIDZK7ZD-Wpt-d9NsR-2FnscgzkT0sSmsxWBJ5c9AvB4cet_3NFN-NPvGWt97z_wMpFM1r">