<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=""><br class=""><div><blockquote type="cite" class=""><div class="">On Jul 13, 2016, at 3:57 PM, Duncan P. N. Exon Smith <<a href="mailto:dexonsmith@apple.com" class="">dexonsmith@apple.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><span style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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; float: none; display: inline !important;" class="">+cfe-dev, bcc:llvm-dev (added back the wrong list I think?)</span><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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;" class=""><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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;" class=""><blockquote type="cite" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px;" class="">On 2016-Jul-13, at 09:57, Duncan P. N. Exon Smith <<a href="mailto:dexonsmith@apple.com" class="">dexonsmith@apple.com</a>> wrote:<br class=""><br class="">+llvm-dev<br class=""><br class=""><blockquote type="cite" class="">On 2016-Jul-13, at 07:38, David Blaikie <<a href="mailto:dblaikie@gmail.com" class="">dblaikie@gmail.com</a>> wrote:<br class=""><br class=""><br class=""><br class="">On Tue, Jul 12, 2016 at 6:52 PM Duncan P. N. Exon Smith via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a>> wrote:<br class="">The status quo isn't "linkonce_odr + visibility_hidden". The status quo is "linkonce_odr + visibility_hidden + always_inline". I guess you're suggesting removing the always_inline?<br class=""><br class="">I believe the "always_inline" is protecting against some objects being built separately from (and with a slightly different libc++ than) others, which is common in the case of static archives. Using "internal" gives the same protection.<br class=""><br class="">Aside from address-taken functions (where the address of functions will depend on the translation unit, instead of causing a link error), I think "internal" is a strict improvement over the status quo. Changing to "linkonce_odr + hidden" would be more fragile, although a possible tradeoff for some vendors.<br class=""><br class="">Even with internal linkage, the linker will have the opportunity to de-duplicate the functions if they are optimized the same way.<br class=""><br class="">It will? Don't the addresses still have to be distinct? (I could pass a pointer to an internal linkage function across a TU boundary to some other TU where it should compare inequal to an equivalent but distinct internal linkage function in that other TU, I would think?)<br class=""><br class="">(& do any of our common linkers do that deduplication (rightly (by adding little thunks) or wrongly (well, MSVC does, but possibly with coordination from the compiler with the "ICF" feature))?)<br class=""></blockquote><br class="">ld64 does de-duplication, but I'm not entirely sure of when.<br class=""></blockquote><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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;" class=""><span style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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; float: none; display: inline !important;" class="">I looked into de-duplication more and talked to Nick. Here is the current state on Darwin:</span><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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;" class=""><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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;" class=""><span style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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; float: none; display: inline !important;" class="">1. If a function in LLVM has "linkonce_odr" linkage and its address is never taken, LLVM emits it with a special flag called "autohide”.</span><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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;" class=""></div></blockquote><div><br class=""></div><div>As a side note, this corresponds to the recently introduced function attribute “ local_unnamed_addr”, and I think lld is doing this “internalization” with LTO now using this attribute.</div><div><br class=""></div><div>— </div><div>Mehdi</div><div><br class=""></div><div><br class=""></div><br class=""><blockquote type="cite" class=""><div class=""><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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;" class=""><span style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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; float: none; display: inline !important;" class="">2. After coalescing symbols, ld64 will internalize any that was marked with "autohide". This optimization reduces the number of weak symbols. (Since (a) the address wasn't taken, (b) the symbol is discardable, and (c) it's following the ODR rule, there is no semantic change from internalizing it.)</span><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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;" class=""><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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;" class=""><span style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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; float: none; display: inline !important;" class="">3. ld64 then de-duplicates any of these "autohidden" symbols by content. (Since the compiler only adds "autohide" to symbols whose address isn't taken, there is no semantic change from de-duplication.)</span><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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;" class=""><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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;" class=""><span style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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; float: none; display: inline !important;" class="">In theory, we could abuse the "autohide" flag by adding it to "internal" symbols, and teach ld64 to de-duplicate those. It's not clear if the link-time overhead would be worth the benefit in general, but it's technically feasible.</span><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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;" class=""><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; 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;" class=""><blockquote type="cite" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px;" class=""><br class=""><blockquote type="cite" class=""><br class=""><br class=""><blockquote type="cite" class="">On 2016-Jul-12, at 18:38, Mehdi Amini via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a>> wrote:<br class=""><br class="">Hi Evgenii,<br class=""><br class="">I have one question about this (planned) change: what if a function is not inlined? The linker will not ODR merge them with this change, which isn’t great.<br class=""><br class="">What makes “internal” linkage more desirable than "linkonce_odr + visibility hidden"?<br class=""><br class="">—<br class="">Mehdi<br class=""><br class=""><br class=""><blockquote type="cite" class="">On Jul 12, 2016, at 6:16 PM, Evgenii Stepanov via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a>> wrote:<br class=""><br class="">Hi,<br class=""><br class="">it's been put on hold for other higher priority work. I still want to<br class="">get it done one day, but it's not clear when that would be.<br class=""><br class="">On Tue, Jul 12, 2016 at 6:11 PM, Akira Hatanaka <<a href="mailto:ahatanak@gmail.com" class="">ahatanak@gmail.com</a>> wrote:<br class=""><blockquote type="cite" class="">Hi Evgenii,<br class=""><br class="">I was wondering what the status is of your work to attach "internal_linkage"<br class="">to methods of standard library classes in libc++. The following piece of<br class="">code doesn't link because a symbol (string::empty) is undefined and it<br class="">sounds like your work might fix the linkage error I'm seeing.<br class=""><br class="">$ cat test1.cpp<br class="">#include <string><br class="">#include <functional><br class=""><br class="">int main() {<br class="">using namespace std::placeholders;<br class="">auto b = std::bind(&std::string::empty, _1);<br class="">}<br class=""><br class="">On Mon, Nov 9, 2015 at 1:58 PM, Evgenii Stepanov via llvm-dev<br class=""><<a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a>> wrote:<br class=""><blockquote type="cite" class=""><br class="">In fact, during the code review we've decided against allowing this<br class="">attribute on namespaces: <a href="http://reviews.llvEm.org/D13925" class="">http://reviews.llvEm.org/D13925</a><br class=""><br class=""><br class="">The intended use of this attribute in libc++ is on functions that<br class="">programs are not allowed to take address of, like all methods of<br class="">standard library classes. Visibility("hidden") attribute (which we are<br class="">replacing with internal_linkage) violates ODR the same way.<br class=""><br class="">Also, this attribute (for us) is not about locality or performance.<br class="">Its primary purpose is to reliably exclude a class method from the<br class="">export table. This is the way libc++ manages ABI stability: all class<br class="">methods that are not part of the library ABI are defined in the<br class="">headers with a set of attributes that ensure that they become internal<br class="">to the translation unit. Always_inline does that in almost all cases,<br class="">but almost is not good enough. Internal_linkage is a straighforward<br class="">way to achieve the same.<br class=""><br class=""><br class="">On Mon, Nov 9, 2015 at 1:34 PM, Martin J. O'Riordan<br class=""><<a href="mailto:martin.oriordan@movidius.com" class="">martin.oriordan@movidius.com</a>> wrote:<br class=""><blockquote type="cite" class="">With respect only to '__attribute__((internal_linkage))', not 'nodebug'<br class="">and other parts of this topic; does hiding "some" members and not others not<br class="">introduce a violation of the ODR because some members of the class as it<br class="">appears in one translation unit are not the same actual definitions as the<br class="">apparently "same" members of the class in another translation unit? In<br class="">particular the ODR requirement that would ensure that the address of a<br class="">method was the same regardless of where the address was taken, including<br class="">'static' methods (no 'this' pointer)? Or hidden things like the guard<br class="">variables for local static objects, default argument initialisers (which are<br class="">instanced), etc.?<br class=""><br class="">I must admit that having spent years trying to lock down the definition<br class="">of the ODR, that this seems to fly in the opposite direction of the intent<br class="">of that rule.<br class=""><br class="">I can (sort of) see why for particular reasons of locality you might<br class="">want multiple actual definitions, even though they might exhibit the same<br class="">behaviour, but maybe the answer for locality optimisation would be for the<br class="">linker technology to evolve so that multiple copies of the same definition<br class="">(sic) could be made; perhaps even at the Basic Block level [Block Level<br class="">Linking]. But this too would lie under the auspices of the "as if" rule and<br class="">respect the ODR.<br class=""><br class="">There is something I am missing in this that is not making me at all<br class="">comfortable about the use of this attribute for namespaces (apart from the<br class="">reopening issues raised by others), and in particular the application to<br class="">parts of a class but not the whole class. I just feel that this is leading<br class="">to semantic trouble.<br class=""><br class="">Thanks,<br class=""><br class=""> MartinO<br class=""><br class="">-----Original Message-----<br class="">From: Evgenii Stepanov [<a href="mailto:eugeni.stepanov@gmail.com" class="">mailto:eugeni.stepanov@gmail.com</a>]<br class="">Sent: 09 November 2015 18:49<br class="">To: Robinson, Paul <<a href="mailto:Paul_Robinson@playstation.sony.com" class="">Paul_Robinson@playstation.sony.com</a>><br class="">Cc: Chris Lattner <<a href="mailto:clattner@apple.com" class="">clattner@apple.com</a>>;<br class=""><a href="mailto:sstewartgallus00@mylangara.bc.ca" class="">sstewartgallus00@mylangara.bc.ca</a>; <a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a>; Martin J.<br class="">O'Riordan <<a href="mailto:martin.oriordan@movidius.com" class="">martin.oriordan@movidius.com</a>><br class="">Subject: Re: [llvm-dev] [cfe-dev] [RFC]<br class="">__attribute__((internal_linkage))<br class=""><br class="">Sorry, I totally missed updates to this thread.<br class=""><br class="">Anonymous namespace does not work for libc++ because we need to hide<br class="">some class members, and export the rest. Namespace would hide all of them.<br class="">AFAIK, "static" is un-deprecated in C++11 for multiple reasons, including<br class="">this one.<br class=""><br class="">I agree that nodebug should not affect codegen. It would also kill debug<br class="">info (ex. all debug locations in libc++ headers).<br class=""><br class=""><br class="">On Mon, Nov 2, 2015 at 11:57 AM, Robinson, Paul via llvm-dev<br class=""><<a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a>> wrote:<br class=""><blockquote type="cite" class=""><br class=""><br class=""><blockquote type="cite" class="">-----Original Message-----<br class="">From: llvm-dev [<a href="mailto:llvm-dev-bounces@lists.llvm.org" class="">mailto:llvm-dev-bounces@lists.llvm.org</a>] On Behalf Of<br class="">Chris Lattner via llvm-dev<br class="">Sent: Saturday, October 31, 2015 2:58 PM<br class="">To: <a href="mailto:sstewartgallus00@mylangara.bc.ca" class="">sstewartgallus00@mylangara.bc.ca</a><br class="">Cc: LLVM Developers<br class="">Subject: Re: [llvm-dev] [cfe-dev] [RFC]<br class="">__attribute__((internal_linkage))<br class=""><br class="">Hi Stewart,<br class=""><br class="">I saw this get brought up at the LLVM devmtg in the context of<br class="">improving the stack size of libc++ frames.<br class=""><br class="">Have you guys considered a different approach to solving this<br class="">problem? In the case of libc++, the _LIBCPP_INLINE_VISIBILITY macro<br class="">currently expands out to "__attribute__ ((__always_inline__))”. It<br class="">seems reasonable to me to have it also add the “nodebug” attribute as<br class="">well. This should allow the allocas generated by inlining lots of<br class="">frames to be promoted to registers (because there is no debug info to<br class="">pessimize).<br class=""></blockquote><br class="">Are you suggesting that 'nodebug' should affect code generation?<br class="">It most definitely should not...<br class="">--paulr<br class=""><br class=""><blockquote type="cite" class=""><br class="">This would dramatically shrink the stack frames of code using libc++<br class="">at - O0, and would also make it go a lot faster.<br class=""><br class="">-Chris<br class=""><br class=""><br class=""><blockquote type="cite" class="">On Oct 29, 2015, at 6:35 AM, Martin J. O'Riordan via llvm-dev<br class=""><llvm-<br class=""></blockquote><a href="mailto:dev@lists.llvm.org" class="">dev@lists.llvm.org</a>> wrote:<br class=""><blockquote type="cite" class=""><br class="">I haven't been able to figure out from this thread why this<br class="">attribute is<br class=""></blockquote>necessary at all.<br class=""><blockquote type="cite" class=""><br class="">Anonymous or unnamed namespaces were added to C++ for this very<br class="">purpose,<br class=""></blockquote>but the ISO C++ Standard does not discuss "linkage" per-se because it<br class="">is outside the scope of the language specification. But it does<br class="">describes it in terms of having a hidden name which is "unique" to<br class="">the translation unit, and under the "as if" rule, internal linkage is<br class="">a common convention for achieving this.<br class=""><blockquote type="cite" class=""><br class="">This is just Standardese for dealing with what compiler<br class="">implementers<br class=""></blockquote>typically handle as "internal linkage" anyway; at the same time, the<br class="">use of 'static' for this purpose was deprecated. This is<br class="">specifically stated in C++98 section 7.3.1.1 and unnamed namespaces<br class="">are still similarly defined in C++17 (Working Paper) although the<br class="">specific reference to the deprecation of 'static' for this purpose is<br class="">now gone.<br class=""><blockquote type="cite" class=""><br class="">The closest the Standard gets to talking about linkage is with<br class="">Linkage<br class=""></blockquote>Specifications, and even here it tries to avoid to avoid treading on<br class="">the definitions things like internal versus external linkage.<br class=""><blockquote type="cite" class=""><br class="">So I am curious, what does this proposed attribute on namespaces<br class="">achieve<br class=""></blockquote>that cannot already be achieved with an anonymous or unnamed<br class="">namespace?<br class=""><blockquote type="cite" class=""><br class="">Thanks,<br class=""><br class="">Martin O'Riordan - Movidius Ltd.<br class=""><br class="">-----Original Message-----<br class="">From: cfe-dev [<a href="mailto:cfe-dev-bounces@lists.llvm.org" class="">mailto:cfe-dev-bounces@lists.llvm.org</a>] On Behalf Of<br class=""></blockquote>Evgenii Stepanov via cfe-dev<br class=""><blockquote type="cite" class="">Sent: 23 October 2015 22:41<br class="">To: Steven Stewart-Gallus <<a href="mailto:sstewartgallus00@mylangara.bc.ca" class="">sstewartgallus00@mylangara.bc.ca</a>><br class="">Cc: Clang Dev <<a href="mailto:cfe-dev@lists.llvm.org" class="">cfe-dev@lists.llvm.org</a>><br class="">Subject: Re: [cfe-dev] [RFC] __attribute__((internal_linkage))<br class=""><br class="">Sounds right. The proposed attribute is a rough equivalent of<br class=""><br class="">static void foo::do_method(void)<br class="">{<br class="">// implementation here<br class="">}<br class=""><br class="">where "static" does not mean a static class member, but makes the<br class=""></blockquote>declaration local to the translation unit. C-style "static".<br class=""><blockquote type="cite" class=""><br class="">The patch in <a href="http://reviews.llvm.org/D13925" class="">http://reviews.llvm.org/D13925</a> (waiting for review,<br class="">btw!)<br class=""></blockquote>supports this attribute on classes and namespaces, with this syntax:<br class=""><blockquote type="cite" class=""><br class="">namespace __attribute__((internal_linkage)) { }<br class=""><br class=""><br class="">On Fri, Oct 23, 2015 at 9:03 AM, Steven Stewart-Gallus via cfe-dev<br class=""><cfe-<br class=""></blockquote><a href="mailto:dev@lists.llvm.org" class="">dev@lists.llvm.org</a>> wrote:<br class=""><blockquote type="cite" class=""><blockquote type="cite" class="">Hello,<br class=""><br class="">Can I ask for some clarification?<br class=""><br class="">Apparently, C++ doesn't allow to static class methods?<br class=""><br class="">While in C one might write inside a header file:<br class=""><br class="">static inline void mylib_foo_do_method(struct mylib_foo *foo) {<br class="">// implementation here<br class="">}<br class=""><br class="">In C++ the typical style would be to write something like:<br class=""><br class="">namespace mylib {<br class=""><br class="">void foo::do_method(void)<br class="">{<br class="">// implementation here<br class="">}<br class="">}<br class=""><br class="">Unfortunately, the C++ case then implies some linkage behaviour<br class="">that some might not want.<br class=""><br class="">Apparently, one can't do things like:<br class=""><br class="">namespace mylib {<br class=""><br class="">static void foo::do_method(void)<br class="">{<br class="">// implementation here<br class="">}<br class="">}<br class=""><br class="">Or,<br class=""><br class="">namespace {<br class="">namespace mylib {<br class=""><br class="">static void foo::do_method(void)<br class="">{<br class="">// implementation here<br class="">}<br class="">}<br class="">}<br class=""><br class="">Also, if you wanted to an attribute to a whole namespace you<br class="">should do something like the following I think:<br class=""><br class="">namespace mylib {<br class="">[[clang::internal_linkage]];<br class=""><br class="">static void foo::do_method(void)<br class="">{<br class="">// implementation here<br class="">}<br class="">}<br class=""><br class=""><br class="">Thank you,<br class="">Steven Stewart-Gallus<br class="">_______________________________________________<br class="">cfe-dev mailing list<br class=""><a href="mailto:cfe-dev@lists.llvm.org" class="">cfe-dev@lists.llvm.org</a><br class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-dev<br class=""></blockquote>_______________________________________________<br class="">cfe-dev mailing list<br class=""><a href="mailto:cfe-dev@lists.llvm.org" class="">cfe-dev@lists.llvm.org</a><br class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-dev<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="">LLVM Developers mailing list<br class=""><a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a><br class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev<br class=""></blockquote>_______________________________________________<br class="">LLVM Developers mailing list<br class=""><a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a><br class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev<br class=""></blockquote><br class=""></blockquote>_______________________________________________<br class="">LLVM Developers mailing list<br class=""><a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a><br class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev<br class=""></blockquote><br class=""><br class=""></blockquote>_______________________________________________<br class="">LLVM Developers mailing list<br class=""><a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a><br class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev<br class=""></blockquote><br class="">_______________________________________________<br class="">LLVM Developers mailing list<br class=""><a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a><br class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev<br class=""></blockquote><br class="">_______________________________________________<br class="">LLVM Developers mailing list<br class=""><a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a><br class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</blockquote></blockquote></div></blockquote></div><br class=""></body></html>