<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><div><blockquote type="cite" class=""><div class="">On Mar 11, 2016, at 8:33 AM, Reid Kleckner <<a href="mailto:rnk@google.com" class="">rnk@google.com</a>> wrote:</div><div class=""><div dir="ltr" class=""><div class="gmail_extra"><div class="gmail_quote">On Thu, Mar 10, 2016 at 10:32 PM, John McCall via llvm-dev <span dir="ltr" class=""><<a href="mailto:llvm-dev@lists.llvm.org" target="_blank" class="">llvm-dev@lists.llvm.org</a>></span> wrote:<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div style="word-wrap:break-word" class="">I mean, I’ve never really liked ELF’s stance on symbol interposition, but taking it as given, I’m not sure I agree that it’s reasonable to carve out virtual functions as a general exception.</div></blockquote><div class=""><br class=""></div><div class="">Given that LLVM does IPO (inlining, funcattrs) on symbols that can be interposed on ELF, we already don't support interposability very well:</div><div class=""><a href="https://llvm.org/bugs/show_bug.cgi?id=23501" class="">https://llvm.org/bugs/show_bug.cgi?id=23501</a><br class=""></div><div class=""><br class=""></div><div class="">Adding another exception for virtual functions, especially under an off-by-default flag, doesn't seem like a big deal.</div></div></div></div></div></blockquote><div><br class=""></div>Okay, so, it sounds to me like LLVM basically treats strong definitions as protected, then. Should we just formalize that?</div><div><br class=""></div><div>I guess the proposal here would be:</div><div> 1. Remove protected visibility from LLVM. (Or deprecate it as equivalent to default.)</div><div> 2. Teach the ELF emitter to emit non-hidden strong definitions using ELF protected visibility.</div><div> 3. Teach the ELF emitter to emit non-hidden weak definitions using ELF default visibility (unless they’re unnamed_addr?).</div><div><br class=""></div><div>GCC must do *some* inlining between strong definitions. Do you know what their rule is? Is it just a C++ thing?</div><div><br class=""></div><div>John.</div><div><br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" class=""><div class="gmail_extra"><div class="gmail_quote"><div class=""> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div style="word-wrap:break-word" class=""><div class="">Isn’t there some global flag to make (non-weak?) definitions use protected visibility by default? Wouldn’t using that be an overall performance win anyway?</div></div></blockquote><div class=""><br class=""></div><div class="">Joerg mentioned -Bsymbolic, but I'm surprised that I don't see people use -Bsymbolic-functions more often. C++ has the ODR, so we can say that all definitions of the same (C++!) function must be equivalent, and it doesn't matter which you call. Programs very rarely rely on function pointer identity across DSOs, and it already isn't preserved on a number of platforms (MSVC does ICF). Typically only global data needs to be coalesced across DSOs, so that things like static data members of templates and static locals in inline functions work.</div></div></div></div>
</div></blockquote></div><br class=""></body></html>