<html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class=""><br class=""><div><br class=""><blockquote type="cite" class=""><div class="">On Jan 3, 2018, at 10:25 AM, John McCall <<a href="mailto:rjmccall@gmail.com" class="">rjmccall@gmail.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; -webkit-text-stroke-width: 0px;" class="">On Wed, Jan 3, 2018 at 12:24 PM, Akira Hatanaka<span class="Apple-converted-space"> </span><span dir="ltr" class=""><<a href="mailto:ahatanaka@apple.com" target="_blank" class="">ahatanaka@apple.com</a>></span><span class="Apple-converted-space"> </span>wrote:<br class=""><div class="gmail_extra"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div style="word-wrap: break-word; line-break: after-white-space;" class=""><div dir="auto" style="word-wrap: break-word; line-break: after-white-space;" class=""><div dir="auto" style="word-wrap: break-word; line-break: after-white-space;" class=""><div dir="auto" style="word-wrap: break-word; line-break: after-white-space;" class=""><div dir="auto" style="word-wrap: break-word; line-break: after-white-space;" class=""><div dir="auto" style="word-wrap: break-word; line-break: after-white-space;" class=""><div class=""><div class=""><div class="h5"><blockquote type="cite" class=""><div class="">On Jan 2, 2018, at 9:42 AM, David Blaikie via cfe-commits <<a href="mailto:cfe-commits@lists.llvm.org" target="_blank" class="">cfe-commits@lists.llvm.org</a>> wrote:</div><br class="m_-7956724118214722485Apple-interchange-newline"><div class=""><div dir="ltr" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px;" class=""><br class=""><br class=""><div class="gmail_quote"><div dir="ltr" class="">On Tue, Dec 19, 2017 at 9:43 PM Akira Hatanaka <<a href="mailto:ahatanak@gmail.com" target="_blank" class="">ahatanak@gmail.com</a>> wrote:<br class=""></div><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div dir="ltr" class=""><div class="gmail_extra"><div class="gmail_quote">On Tue, Dec 12, 2017 at 12:12 PM, John McCall<span class="m_-7956724118214722485Apple-converted-space"> </span><span dir="ltr" class=""><<a href="mailto:rjmccall@gmail.com" target="_blank" class="">rjmccall@gmail.com</a>></span><span class="m_-7956724118214722485Apple-converted-space"> </span>wr<wbr class="">ote:<br class=""><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div dir="ltr" class=""><div class=""><div class="m_-7956724118214722485m_-1976606938441742476gmail-m_-8969288968174730138gmail-h5">On Tue, Dec 12, 2017 at 1:45 PM, David Blaikie<span class="m_-7956724118214722485Apple-converted-space"> </span><span dir="ltr" class=""><<a href="mailto:dblaikie@gmail.com" target="_blank" class="">dblaikie@gmail.com</a>></span><span class="m_-7956724118214722485Apple-converted-space"> </span>w<wbr class="">rote:<br class=""></div></div><div class="gmail_extra"><div class="gmail_quote"><div class=""><div class="m_-7956724118214722485m_-1976606938441742476gmail-m_-8969288968174730138gmail-h5"><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div dir="ltr" class=""><span style="color: rgb(80, 0, 80);" class="">On Mon, Dec 11, 2017 at 5:38 PM John McCall <</span><a href="mailto:rjmccall@gmail.com" target="_blank" class="">rjmccall@gmail.com</a><span style="color: rgb(80, 0, 80);" class="">> wrote:</span><br class=""><div class="gmail_quote"><div class=""><div class="m_-7956724118214722485m_-1976606938441742476gmail-m_-8969288968174730138gmail-m_-2329063236051570055h5"><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div dir="ltr" class="">On Mon, Dec 11, 2017 at 6:19 PM, David Blaikie<span class="m_-7956724118214722485Apple-converted-space"> </span><span dir="ltr" class=""><<a href="mailto:dblaikie@gmail.com" target="_blank" class="">dblaikie@gmail.com</a>></span><span class="m_-7956724118214722485Apple-converted-space"> </span>w<wbr class="">rote:<br class=""></div><div dir="ltr" class=""><div class="gmail_extra"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div dir="ltr" class="">On Mon, Dec 11, 2017 at 3:16 PM John McCall via Phabricator <<a href="mailto:reviews@reviews.llvm.org" target="_blank" class="">reviews@reviews.llvm.org</a>> wrote:<br class=""><div class="gmail_quote"><span class="m_-7956724118214722485m_-1976606938441742476gmail-m_-8969288968174730138gmail-m_-2329063236051570055m_6617752451251688076m_-4185080464891481584gmail-"><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;">rjmccall added a comment.<br class=""><br class="">In<span class="m_-7956724118214722485Apple-converted-space"> </span><a href="https://reviews.llvm.org/D41039#951648" rel="noreferrer" target="_blank" class="">https://reviews.llvm.org/<wbr class="">D41039#951648</a>, @ahatanak wrote:<br class=""><br class="">> I had a discussion with Duncan today and he pointed out that perhaps we shouldn't allow users to annotate a struct with "trivial_abi" if one of its subobjects is non-trivial and is not annotated with "trivial_abi" since that gives users too much power.<br class="">><br class="">> Should we error out or drop "trivial_abi" from struct Outer when the following code is compiled?<br class="">><br class="">> struct Inner1 {<br class="">> ~Inner1(); // non-trivial<br class="">> int x;<br class="">> };<br class="">><br class="">> struct __attribute__((trivial_abi)) Outer {<br class="">> ~Outer();<br class="">> Inner1 x;<br class="">> };<br class="">><br class="">><br class="">> The current patch doesn't error out or drop the attribute, but the patch would probably be much simpler if we didn't allow it.<br class=""><br class=""><br class="">I think it makes sense to emit an error if there is provably a non-trivial-ABI component. However, for class temploids I think that diagnostic should only fire on the definition, not on instantiations; for example:<br class=""><br class=""> <span class="m_-7956724118214722485Apple-converted-space"> </span>template <class T> struct __attribute__((trivial_abi)) holder {<br class=""> T value;<br class=""> ~holder() {}<br class=""> <span class="m_-7956724118214722485Apple-converted-space"> </span>};<br class=""> <span class="m_-7956724118214722485Apple-converted-space"> </span>holder<std::string> hs; // this instantiation should be legal despite the fact that holder<std::string> cannot be trivial-ABI.<br class=""><br class="">But we should still be able to emit the diagnostic in template definitions, e.g.:<br class=""><br class=""> <span class="m_-7956724118214722485Apple-converted-space"> </span>template <class T> struct __attribute__((trivial_abi)) named_holder {<br class=""> std::string name; // there are no instantiations of this template that could ever be trivial-ABI<br class=""> T value;<br class=""> ~named_holder() {}<br class=""> <span class="m_-7956724118214722485Apple-converted-space"> </span>};<br class=""><br class="">The wording should be something akin to the standard template rule that a template is ill-formed if it has no valid instantiations, no diagnostic required.<br class=""><br class="">I would definitely like to open the conversation about the name of the attribute. I don't think we've used "abi" in an existing attribute name; usually it's more descriptive. And "trivial" is a weighty word in the standard. I'm not sure I have a great counter-proposal off the top of my head, though.<br class=""></blockquote></span><div class=""><br class="">Agreed on both counts (would love a better name, don't have any stand-out candidates off the top of my head).<br class=""><br class="">I feel like a more descriptive term about the property of the object would make me happier - something like "address_independent_identity" (s/identity/value/?) though, yeah, that's not spectacular by any stretch.<br class=""></div></div></div></blockquote><div class=""><br class=""></div></div></div></div><div dir="ltr" class=""><div class="gmail_extra"><div class="gmail_quote"><div class="">Incidentally, your comments are not showing up on Phabricator for some reason.</div></div></div></div></blockquote></div></div><div class=""><br class="">Yeah, Phab doesn't do a great job looking on the mailing list for interesting replies - I forget, maybe it only catches bottom post or top post but not infix replies or something... <br class=""></div></div></div></blockquote><div class=""><br class=""></div></div></div><div class="">Well, fortunately the mailing list is also archived. :)</div><span class="m_-7956724118214722485m_-1976606938441742476gmail-m_-8969288968174730138gmail-"><div class=""><br class=""></div><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div dir="ltr" class=""><div class="gmail_quote"><div class=""><br class=""></div><span class=""><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div dir="ltr" class=""><div class="gmail_extra"><div class="gmail_quote"><div class="">The term "trivially movable" suggests itself, with two caveats:<br class=""></div><div class=""> <span class="m_-7956724118214722485Apple-converted-space"> </span>- What we're talking about is trivial *destructive* movability, i.e. that the combination of moving the value to a new object and not destroying the old object can be done trivially, which is not quite the same as trivial movability in the normal C++ sense, which I guess could be a property that someone theoretically might care about (if the type is trivially destructed, but it isn't copyable for semantic reasons?).</div><div class=""> <span class="m_-7956724118214722485Apple-converted-space"> </span>- Trivial destructive movability is a really common property, and it's something that a compiler would really like to optimize based on even in cases where trivial_abi can't be adopted for binary-compatibility reasons. Stealing the term for the stronger property that the type is trivially destructively movable *and its ABI should reflect that in a specific way* would be unfortunate.</div></div></div></div></blockquote></span><div class=""><br class="">Fair point.<br class=""> </div><span class=""><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div dir="ltr" class=""><div class="gmail_extra"><div class="gmail_quote"><div class="">"trivially_movable" is a long attribute anyway, and "trivially_destructively_<wbr class="">movable" is even worse.<br class=""></div><div class=""><br class=""></div><div class="">Maybe that second point is telling us that this isn't purely descriptive — it's inherently talking about the ABI, not just the semantics of the type. I might be talking myself into accepting trivial_abi if we don't end up with a better suggestion.</div></div></div></div></blockquote></span><div class=""><br class="">*nod* I think if you want to slice this that way (ensuring there's space to support describing a similar property for use only in non-ABI-breaking contexts as well) it seems like ABI is the term to use somewhere in the name.<br class=""></div></div></div></blockquote><div class=""><br class=""></div></span><div class="">Yeah. We just had a little internal conversation about it, and the idea of "address_invariant_abi" came up, but I'm not sure it has enough to recommend it over "trivial_abi" to justify the longer name.</div><span class="m_-7956724118214722485m_-1976606938441742476gmail-m_-8969288968174730138gmail-"><div class=""><br class=""></div><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div dir="ltr" class=""><div class="gmail_quote"><div class=""><br class=""></div><span class=""><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div dir="ltr" class=""><div class="gmail_extra"><div class="gmail_quote"><div class="">Random thing that occurred to me: is it actually reasonable to enforce trivial_abi correctness in a non-template context? Templates aren't the only case where a user could reasonably want to add trivial_abi and just have it be suppressed if it's wrong. Imagine if some stdlib made std::string trivial_abi; someone might reasonably want to make my named_holder example above trivial_abi as well, with the expectation that it would only have an effect on targets where std::string was trivial_abi. At the very least, I'm concerned that we might be opening ourselves up to a need to add supporting features, like a way to be conditionally trivial_abi based on context.<br class=""></div></div></div></div></blockquote></span><div class=""><br class="">Fair point, much like the quirky but useful behavior of "= default". Good point about non-dependent contexts still being relevant to this subjective behavior... <br class=""><br class="">I was already leaning towards this being a warning rather than an error - this situation leans me moreso that way & possibly suppressing the warning when the types are split between system and non-system headers (if the attribute's on a type in a non-system header, but the type that's blocking it from being active is in a system header, don't warn).<br class=""></div></div></div></blockquote><div class=""><br class=""></div></span><div class="">That's an interesting idea.</div><span class="m_-7956724118214722485m_-1976606938441742476gmail-m_-8969288968174730138gmail-HOEnZb"><font color="#888888" class=""><div class=""><br class=""></div></font></span></div></div></div></blockquote><div class=""><br class=""></div></div></div></div><div dir="ltr" class=""><div class="gmail_extra"><div class="gmail_quote"><div class="">OK, so if a trivial_abi class has a component that is not trivial, we drop the trivial_abi from the containing class. Also, we may decide not to error out or warn if the attribute is on a template or the non-trivial class comes from a system header.</div><div class=""><br class=""></div><div class="">What would the rules be for propagating the trivial_abi property outwards? I tried to extend the existing standard rules for determining whether a special function is trivial to trivial_abi or whether a type should be forced to be passed indirectly in my first patch, but it looks like that approach is too complicated.</div></div></div></div></blockquote><div class=""><br class="">What makes it too complicated? That would seem unfortunate to diverge here, I would think..<br class=""> </div></div></div></div></blockquote><div class=""><br class=""></div></div></div><div class=""><div class="">Based on my understanding of the discussion yesterday, I think we’ve decided not to diverge from the standard:</div><div class=""><br class=""></div><div class=""><a href="http://lists.llvm.org/pipermail/cfe-commits/Week-of-Mon-20180101/thread.html#214043" target="_blank" class="">http://lists.llvm.org/<wbr class="">pipermail/cfe-commits/Week-of-<wbr class="">Mon-20180101/thread.html#<wbr class="">214043</a></div><div class=""><br class=""></div></div><div class="">My patch keeps track of the triviality of special functions using two bitfields in CXXRecordDecl (HasTrivialSpecialMembers and HasTrivialSpecialMembersForCal<wbr class="">l) and two flags in FunctionDecl (IsTrivial and IsTrivialForCall) because it needs to distinguish between triviality according to the current standard’s definition and triviality for the purpose of calls. Those flags have to be updated in various places, which I thought might be too complicated.</div></div></div></div></div></div></div></div></blockquote><div class=""><br class=""></div><div class="">Well, we're not changing the definition of triviality, and the intent is that we're not changing the definition of triviality-for-calls (as standardized by Itanium) in the absence of the trivial_abi attribute.</div><div class=""><br class=""></div><div class="">Under the definition we developed in that thread, I think your new tracking bits are unavoidable.</div><div class=""><br class=""></div></div></div></div></div></blockquote><div><br class=""></div>Yes, I think they are unavoidable.</div><div><br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; -webkit-text-stroke-width: 0px;" class=""><div class="gmail_extra"><div class="gmail_quote"><div class="">John.</div><div class=""> </div><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div style="word-wrap: break-word; line-break: after-white-space;" class=""><div dir="auto" style="word-wrap: break-word; line-break: after-white-space;" class=""><div dir="auto" style="word-wrap: break-word; line-break: after-white-space;" class=""><div dir="auto" style="word-wrap: break-word; line-break: after-white-space;" class=""><div dir="auto" style="word-wrap: break-word; line-break: after-white-space;" class=""><div dir="auto" style="word-wrap: break-word; line-break: after-white-space;" class=""><div class=""><div class=""><br class=""></div><blockquote type="cite" class=""><div class=""><span class=""><div dir="ltr" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px;" class=""><div class="gmail_quote"><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div dir="ltr" class=""><div class="gmail_extra"><div class="gmail_quote"><div class="">I'm thinking about using the following rules instead. What do you think?<br class=""></div><div class=""><br class=""></div><div class="">trivial_abi=true for a class if it meets the following conditions:<br class=""></div><div class=""><br class=""></div><div class=""><div class="">1. it has attribute "trivial_abi" or<br class=""></div></div><div class="">2. if it doesn't have attribute "trivial_abi", it must meet all of the following conditions:</div><div class=""> 2-1. it doesn't have any virtual functions or virtual bases and</div><div class=""> 2-2. it doesn't have any members that would cause the type to be non-trivial (e.g., __weak objc pointers) and</div><div class=""> 2-3. it doesn't have any user-provided copy constructors, move constructors, or destructors (explicitly defaulted methods are OK) and<br class=""></div><div class=""> 2-4. trivial_abi=true for all of its base classes and members</div><div class=""><br class=""></div><div class="">These rules apply only when the class or the type of one of its members or base classes has attribute "trivial_abi". The existing rules in the standard will be used to determine whether clang should force a type to be passed indirectly if none of the classes in the class hierarchy have attribute "trivial_abi".</div><div class=""> </div><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div dir="ltr" class=""><div class="gmail_extra"><div class="gmail_quote"><span class="m_-7956724118214722485m_-1976606938441742476gmail-m_-8969288968174730138gmail-HOEnZb"><font color="#888888" class=""><div class=""></div><div class="">John.</div></font></span></div></div></div></blockquote></div><br class=""></div></div></blockquote></div></div></span><span style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; float: none; display: inline !important;" class="">______________________________<wbr class="">_________________</span><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px;" class=""><span style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; float: none; display: inline !important;" class="">cfe-commits mailing list</span><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px;" class=""><span style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; float: none; display: inline !important;" class=""><a href="mailto:cfe-commits@lists.llvm.org" target="_blank" class="">cfe-commits@lists.llvm.org</a></span><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px;" class=""><span style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; float: none; display: inline !important;" class=""><a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits" target="_blank" class="">http://lists.llvm.org/cgi-bin/<wbr class="">mailman/listinfo/cfe-commits</a></span></div></blockquote></div><br class=""></div></div></div></div></div></div></blockquote></div><br class=""><br clear="all" class=""><div class=""><br class=""></div>--<span class="Apple-converted-space"> </span><br class=""><div class="gmail_signature" data-smartmail="gmail_signature">I suppose you'd like my real thoughts as well.</div></div></div></div></blockquote></div><br class=""></body></html>