<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Jul 23, 2015 at 2:39 PM, Ben Langmuir <span dir="ltr"><<a href="mailto:blangmuir@apple.com" target="_blank">blangmuir@apple.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word"><br><div><span class=""><blockquote type="cite"><div>On Jul 22, 2015, at 12:56 PM, Sean Silva <<a href="mailto:chisophugis@gmail.com" target="_blank">chisophugis@gmail.com</a>> wrote:</div><br><div><br><br style="font-family:Helvetica;font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:14px;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px"><div class="gmail_quote" style="font-family:Helvetica;font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:14px;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px">On Wed, Jul 22, 2015 at 10:29 AM, Richard Smith<span> </span><span dir="ltr"><<a href="mailto:metafoo@gmail.com" target="_blank">metafoo@gmail.com</a>></span><span> </span>wrote:<br><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"><span><p dir="ltr">On 21 Jul 2015 8:25 pm, "Ben Langmuir" <<a href="mailto:blangmuir@apple.com" target="_blank">blangmuir@apple.com</a>> wrote:<br>><br>> Hi all,<br>><br>> While reviewing<span> </span><a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__reviews.llvm.org_D10423&d=AwMFaQ&c=8hUWFZcy2Z-Za5rBPlktOQ&r=CnzuN65ENJ1H9py9XLiRvC_UQz6u3oG6GUNn7_wosSM&m=JYmiMIpFbfcSnAR3aCmhlEtMtzFs9foTZa96qlWFk2U&s=RkKAjlDc9m_oZ8L2jX1j82WcpQUsPRHwOuhURsGPe6c&e=" target="_blank">http://reviews.llvm.org/D10423</a>, I ran into a problem with our _Builtin_Intrinsics module map file.  It contains a submodule for arm intrinsics:<br>><br>>   explicit module arm {<br>>     requires arm<br>><br>> This doesn’t work as intended, because today only 32bit arm targets publish the “arm” target feature, but this module is supposed to be used on AArch64 as well (e.g. for the arm_neon.h header).  The target features that we can use in a module “requires” declaration are controlled by TargetInfo::hasFeature().  Only module map parsing currently checks for the arm feature.<br>><br>> I propose that we rename the current “arm” feature to “arm32” and take over the name “arm” to mean “arm32 || aarch64”.<br>><br>> Pros<br>> * Mirrors the x86/x86_32/x86_64 feature names and functionality<br>> * Anecdotally, this better matches user expectation of what “requires arm” means<br>><br>> Cons<br>> * This is a backwards-incompatible change if any modules rely on “requires arm” failing on aarch64 targets.<br>><br>> Would this break existing modules for anyone who cannot just add a “requires !aarch64” to their module map? Or does anyone feel strongly that this is the wrong solution?</p></span><p dir="ltr">I agree that this is the right solution, assuming it doesn't break anyone.</p></blockquote><div>Agreed. Realistically I don't expect anybody besides Apple to be shipping modules in a situation where ambiguity with aarch64 could be an issue, so the breakage (if any) should hopefully be limited to apple systems Ben can test.</div></div></div></blockquote><div><br></div></span><div>The Darwin SDKs don’t use the “arm” requirement anywhere.  The only case I’ve come across at all is the one in the clang builtin modules.</div><span class=""><br></span></div></div></blockquote><div><br></div><div>Ok, then since the builtin module will be in sync with its corresponding clang, we should not have any compatibility concern here.</div><div><br></div><div>-- Sean Silva</div><div> </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"><div><span class=""><blockquote type="cite"><div><div class="gmail_quote" style="font-family:Helvetica;font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:14px;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px"><div><br></div><div>-- Sean Silva </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><div><p dir="ltr">> The other possibilities I considered, but felt were worse solutions:<br>> (a) Keep the meaning of “arm” and invent a new feature to mean "arm || aarch64".  Mostly I felt this left the existing name unnecessarily confusing.<br>> (b) accepting the state of the compiler and duplicating the “arm” submodule. In theory, isBetterKnownHeader will allow this to “just work” for #includes, but users would have to spell their @imports differently for different targets, or<br>> (c) adding some general feature to spell disjunctions in module requires decls (this didn’t seem worth it since I can’t think of any other users for such a feature).<br>><br>><br>> Ben<br>></p></div></div></blockquote></div></div></blockquote></span></div><br></div></blockquote></div><br></div></div>