<div dir="ltr"><div dir="auto"><div dir="ltr"><div dir="ltr">On Fri, Sep 11, 2020 at 3:55 PM Hubert Tong <<a href="mailto:hubert.reinterpretcast@gmail.com" rel="noreferrer noreferrer noreferrer" target="_blank">hubert.reinterpretcast@gmail.com</a>> wrote:<br></div><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Sep 11, 2020 at 2:58 PM James Y Knight <<a href="mailto:jyknight@google.com" rel="noreferrer noreferrer noreferrer" target="_blank">jyknight@google.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Sep 10, 2020 at 10:30 PM Hubert Tong <<a href="mailto:hubert.reinterpretcast@gmail.com" rel="noreferrer noreferrer noreferrer" target="_blank">hubert.reinterpretcast@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Sep 10, 2020 at 9:07 PM James Y Knight <<a href="mailto:jyknight@google.com" rel="noreferrer noreferrer noreferrer" target="_blank">jyknight@google.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div dir="auto"><div><br><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Sep 10, 2020, 6:57 PM Hubert Tong <<a href="mailto:hubert.reinterpretcast@gmail.com" rel="noreferrer noreferrer noreferrer noreferrer" target="_blank">hubert.reinterpretcast@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Sep 10, 2020 at 6:30 PM James Y Knight via cfe-dev <<a href="mailto:cfe-dev@lists.llvm.org" rel="noreferrer noreferrer noreferrer noreferrer noreferrer" target="_blank">cfe-dev@lists.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="auto"><div dir="ltr"><div dir="ltr">But <i>why</i> does AIX want to ignore visibility restrictions encoded via attribute? Especially by default?</div></div></div></blockquote>One reason is that AIX performs more early/less lazy symbol resolution (even with runtime linking) than, say, Linux. So, if a project goes with an export-by-default model (via attribute in some scope), they can cause link-time errors from symbol references to undefined symbols from code that would otherwise have been discarded as unreferenced by the linker. It seems such code is not uncommon (and has the questionable effect of exporting template instantiations based on "client provided" types that are not part of the "library"/"utility" code in question).</div></div></blockquote></div></div><div dir="auto"><br></div><div dir="auto">But, the default visibility is "default" -- which is the most export-y visibility setting there is. So, without specifying visibility options on the command line, the only thing you can do with visibility attributes in code is to <i>remove </i>exports, not add additional ones.</div><div dir="auto"><br></div><div dir="auto">What am I missing?</div></div></div></blockquote><div></div><div>That AIX is not an ELF platform. AIX has a default visibility for XCOFF called "unspecified". This is because the ELF-based visibility options do not quite match the base case on AIX. That the most export-y visibility is named "default" at the source level is an ELF-ism.<br></div></div></div></blockquote><div><br></div><div>But Clang doesn't have an "unspecified" visibility, only default, protected, and hidden. And this proposal doesn't propose to add one, either. So I don't see how this command-line option makes sense in Clang, right now.</div></div></div></blockquote><div>It makes sense for Clang on AIX if it improves the consistency of behaviour with other compilers on that platform. GCC on AIX does not support encoding visibility into XCOFF and the default behaviour of the IBM xlclang/xlclang++ compiler on AIX is to not encode visibility into XCOFF. That there will be future complementary changes does not seem to be a practical reason for leaving Clang gratuitously different on AIX from other AIX compilers.<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div class="gmail_quote"><div></div></div></div></blockquote></div></div></blockquote><div><br></div><div>If clang did <i>not</i> implement this feature, symbols marked visibility("hidden") or visibility("protected") will actually be marked hidden/protected in the output on AIX. If clang <i>does</i> implement this feature, such symbols will instead be marked as exported default-visibility. There is no change for symbols marked visibility("default").</div><div><br></div><div>So, the request here is that Clang on AIX should ignore the attempt to hide symbols, resulting in symbols being exported, even though the code thought it was hiding them? That's the desired behavior change?<br></div><div><br></div><div>I remain unclear as to how that is a useful or important feature. Are you worried about compatibility with code which incorrectly specified visibility("hidden"), when it actually did need to export the symbol?</div><div></div><div></div></div></div></div>
</div>