<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 2 Aug 2017, at 00:54, David Blaikie <<a href="mailto:dblaikie@gmail.com" class="">dblaikie@gmail.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class=""><br class=""><br class=""><div class="gmail_quote"><div dir="ltr" class="">On Tue, Aug 1, 2017 at 7:52 AM Dean Michael Berris <<a href="mailto:dberris@google.com" class="">dberris@google.com</a>> wrote:<br class=""></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word" class=""><div class=""><blockquote type="cite" class=""><div class="">On 2 Aug 2017, at 00:49, David Blaikie <<a href="mailto:dblaikie@gmail.com" target="_blank" class="">dblaikie@gmail.com</a>> wrote:</div><br class="m_-3731131061154773572Apple-interchange-newline"><div class=""><div dir="ltr" class=""><br class=""><br class=""><div class="gmail_quote"><div dir="ltr" class="">On Mon, Jul 31, 2017 at 11:18 PM Dean Michael Berris via Phabricator <<a href="mailto:reviews@reviews.llvm.org" target="_blank" class="">reviews@reviews.llvm.org</a>> wrote:<br class=""></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">dberris added a comment.<br class="">
<br class="">
In <a href="https://reviews.llvm.org/D36078#826962" rel="noreferrer" target="_blank" class="">https://reviews.llvm.org/D36078#826962</a>, @kpw wrote:<br class="">
<br class="">
> What's the primary motivation? Are we trying to avoid the upfront cost of global initialization? The unspecified destructor ordering with multithreaded programs?<br class="">
<br class="">
<br class="">
The primary motivation is to avoid the initialization of atomics at initialization time. This has caused some issues in the past with dynamic linking and relocations.<br class=""></blockquote><div class=""><br class="">Correctness issues? Performance issues? Seems like it'd be good to have the issues described more fully here (and/or in the commit(s) for posterity/clarity)<br class=""> </div></div></div></div></blockquote><div class=""><br class=""></div></div></div><div style="word-wrap:break-word" class=""><div class=""><div class="">Runtime crashes during initialisation and incompatibilities. I guess you can call those correctness issues.</div></div></div></blockquote><div class=""><br class="">Is there more detail that could be documented here - basically a full answer to "why can't xray (or compiler-rt in general?) have global initializers?" (if this is a compiler-rt requirement maybe it should be written down somewhere more centrally, if it's only an xray requirement, at least documenting it fully in the commit messages and maybe in some comments could be good)<br class=""></div></div></div></div></blockquote><div><br class=""></div><div>I'm not sure if it's a specific requirement in compiler-rt, but it sounds like a good thing to do for later.</div><div><br class=""></div><div>For the "why can't we have global initialisers" -- it's not exactly "can't", more like, "shouldn't".</div><div><br class=""></div><div>In some esoteric/special cases, where code running before the dynamic linker (or while the dynamic linker is running), having variables that need to be atomically initialised that calls a function accessed through an indirect call (through the PLT or something similar) can cause dependency issues -- and sometimes some crashes. We can't guarantee that the order of linking and code running in .preinit_array will run before the dynamic relocations have finished (as far as I can tell).</div><div><br class=""></div><div>Having no global initializers (or at least ones that are trivial) avoids these observed problems.</div><br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" class=""><div class="gmail_quote"><div class=""><br class="">I'd be curious (& I think it'd be good to write down) to better understand the mechanism of action - how does a global initializer lead to a crash in this instance & what's incompatible/why?<br class=""><br class=""></div></div></div></div></blockquote><div><br class=""></div>I would like to be able to do that exactly too, but I only have anecdotes to show that having no global initialisers limits the number of weird issues encountered with regards to initialisation order and potential for being in an uninitialised state depending on how the binary is linked. Especially with the XRay runtime. I'm not too sure this is a problem with the other sanitisers, but XRay is enough different that the requirements might be very different from say, asan.<br class=""></div></body></html>