<html><head><meta http-equiv="Content-Type" content="text/html charset=us-ascii"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><br class=""><div><blockquote type="cite" class=""><div class="">On 16 Aug 2017, at 04:33, Evgenii Stepanov <<a href="mailto:eugeni.stepanov@gmail.com" class="">eugeni.stepanov@gmail.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div class="">Yes, but it is super tricky to do this correctly across all linkers.<br class="">See how we handle it in ASan. Also, this is quite bad for object file<br class="">size, because now each function section has 2 extra sections - one for<br class="">the data, and one for section group, and those aren't free. (section<br class="">group is necessary to support legacy linkers)<br class=""><br class=""></div></div></blockquote><div><br class=""></div><div>Thanks, Evgenii -- sounds reasonable to me. I'll measure and see whether we can document these binary size costs for XRay to be less of a surprise.</div><div><br class=""></div><div>We also already do have quite a bit of side-table information for XRay, maybe this wouldn't be that much worse (i.e. since we already have the instrumentation map and the function index for instrumented functions, we're already affecting binary size from that front). :)</div><div><br class=""></div><div>Cheers</div><br class=""><blockquote type="cite" class=""><div class=""><div class="">On Tue, Aug 15, 2017 at 9:59 AM, Reid Kleckner <<a href="mailto:rnk@google.com" class="">rnk@google.com</a>> wrote:<br class=""><blockquote type="cite" class="">I think you want to use SHF_LINK_ORDER via !associated metadata. That was<br class="">the conclusion that the generic-abi mailing list came to when trying to<br class="">solve a similar problem for sanitizers:<br class=""><a href="https://groups.google.com/forum/#!searchin/generic-abi/garbage$20collection%7Csort:relevance/generic-abi/_CbBM6T6WeM/LZnqx1KZAQAJ" class="">https://groups.google.com/forum/#!searchin/generic-abi/garbage$20collection%7Csort:relevance/generic-abi/_CbBM6T6WeM/LZnqx1KZAQAJ</a><br class=""><br class="">The side table would end up in a section with the SHF_LINK_ORDER flag set<br class="">and an sh_link pointing at the text section that its associated with.<br class=""><br class="">On Tue, Aug 15, 2017 at 2:37 AM, Dean Michael Berris via llvm-dev<br class=""><llvm-dev@lists.llvm.org> wrote:<br class=""><blockquote type="cite" class=""><br class="">Hi llvm-dev,<br class=""><br class="">I'm currently looking for alternatives to the synthetic references that<br class="">XRay uses to keep some side-tables live, to avoid linker garbage collection<br class="">from deleting those sections. Before going any further, let me give a<br class="">backgrounder on what XRay does today.<br class=""><br class="">Background<br class="">==========<br class=""><br class="">XRay has two side tables we use at runtime to identify the location of the<br class="">sleds for the functions that are instrumented. These are named "xray_fn_idx"<br class="">and "xray_instr_map". We emit information in these sections that refer to<br class="">labels that are emitted in the .text section (or in function-specific<br class="">sections, when building with -ffunction-sections). To keep the entries in<br class="">these sections alive from the linker's perspective, we emit references in<br class="">the .text section (or function-specific sections) that refer to the<br class="">"xray_fn_idx" entry for that function, which in turn refers to the entries<br class="">in "xray_instr_map" that point back to the instrumentation points in .text<br class="">section (or function-specific sections).<br class=""><br class="">Currently, (in X86) we just write out a raw ".quad <label>" reference<br class="">after lowering the function, where <label> is defined in the "xray_fn_idx"<br class="">section. Unfortunately this causes the linker (gold?) to emit a relocation<br class="">in the .text section (TEXTREL in ELF) which interferes unfavourably with GNU<br class="">IFUNC relocations.<br class=""><br class="">Questions<br class="">=========<br class=""><br class="">Is there an alternative to this approach available to us from the LLVM<br class="">back-end? I see that there's ways to define associative COMDAT sections, but<br class="">that's COFF-specific and only works with COMDAT. We instrument XRay<br class="">functions that aren't necessarily defined in COMDAT sections in ELF (or<br class="">COMDAT "group" sections), and would like to be able to keep those two<br class="">sections live.<br class=""><br class="">Alternatively, is there a way for us to mark the relocation to be resolved<br class="">statically (i.e. not a dynamic relocation)? I've tried marking the<br class="">label/symbol defined in the xray_fn_idx section as "hidden" and "local"<br class="">(according to ELF definitions) but that doesn't seem to change the<br class="">relocation emitted in the .text (of function-specific) section. Is there a<br class="">way around this from the back-end, so that, for example, when we emit that<br class="">reference ".quad <???>", what goes in the "???" will not be a dynamic<br class="">relocation?<br class=""><br class="">Or is there a way to instruct the linker to "fix" these relocations?<br class=""><br class="">Cheers<br class=""><br class="">-- Dean<br class=""><br class="">_______________________________________________<br class="">LLVM Developers mailing list<br class="">llvm-dev@lists.llvm.org<br class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev<br class=""></blockquote><br class=""><br class=""></blockquote></div></div></blockquote></div><br class=""><div class="">
<div style="color: rgb(0, 0, 0); letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px; word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><div style="color: rgb(0, 0, 0); letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px; word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class="">-- Dean</div></div>

</div>
<br class=""></body></html>