<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="">Nuno,<div class=""> I am confused, you have not shown why branch on poison should</div><div class="">be defined to be UB, you have shown why “each use of ‘undef’ can yield</div><div class="">a different result” is a bad definition. </div><div class=""><br class=""></div><div class="">So we still don’t have a good reason that justifies “branch on poison is UB”.</div><div class=""><br class=""></div><div class=""><br class=""></div><div class="">Peter Lawrence.</div><div class=""><br class=""></div><div class=""><br class=""><div><blockquote type="cite" class=""><div class="">On Jun 15, 2017, at 7:31 AM, Nuno Lopes <<a href="mailto:nunoplopes@sapo.pt" class="">nunoplopes@sapo.pt</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="">The GVN example we provided was supposed to be a sufficient argument.</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=""><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="">But.. see section 3.2 of the paper you mentioned for another example of why a non-deterministic jump on poison/undef is not a good idea.</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>Here’s what 3.2 says: </div><div><br class=""></div><div><span class="Apple-tab-span" style="white-space:pre"> </span>“Since each use of ‘undef’ can yield a different result, we can have the top level if-condition being true and still divide by zero”,</div><div><br class=""></div><div>it says nothing about branch on undefined or branch on poison.</div><div><br class=""></div><br class=""><blockquote type="cite" class=""><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="">Alternatively see slide 12 of this:<span class="Apple-converted-space"> </span></span><a href="http://llvm.org/devmtg/2016-11/Slides/Lopes-LongLivePoison.pdf" 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="">http://llvm.org/devmtg/2016-11/Slides/Lopes-LongLivePoison.pdf</a><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>Slide 12 is an exact duplicate of the example in the Paper.</div><div><br class=""></div><div>It actually has arrows pointing to the two uses of ‘k’ that can have different values</div><div>because of the bad definition of “undef"</div><div><br class=""></div><br class=""><blockquote type="cite" class=""><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="">And a miscompilation:<span class="Apple-converted-space"> </span></span><a href="https://bugs.llvm.org/show_bug.cgi?id=21412" 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="">https://bugs.llvm.org/show_bug.cgi?id=21412</a><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>Again, this bug shows the exact same thing once you reduce it to simplest form.</div><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="">See also my reply to your email yesterday. You cannot drop poison like you drop nsw; that doesn't exist (currently).</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="">Nuno</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=""></div></blockquote><div><br class=""></div><div><br class=""></div><div><br class=""></div><div><br class=""></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=""><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="">Citando Peter Lawrence via llvm-dev <</span><a href="mailto:llvm-dev@lists.llvm.org" 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="">llvm-dev@lists.llvm.org</a><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="">>:</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="">Daniel,<br class=""> Thanks for taking the time to respond.<br class=""><br class="">Regarding GVN and newGVN, I recently finished a search through the<br class="">llvm-dev archives for “nsw” in the subject line, and GVN was discussed in<br class="">some of those threads [1].<br class=""><br class="">In particular it was claimed that there was a right choice for GVN to make given<br class="">two ADD instructions, one with the “nsw” attribute and one without, the one<br class="">without ‘nsw’ must be the representative.<br class=""><br class="">This was described as a correctness issue, not an optimality issue. IE if you<br class="">are going to CSE those two ADDs, it is safe to loose information (drop the ‘nsw’)<br class="">but it is unsafe to put ‘nsw’ on to an operation that didn’t already have it<br class="">because that is like inserting an “llvm.assume" where there was none.<br class=""><br class="">So I am extrapolating from ’nsw’ instruction attribute, to ‘poison’ value attribute,<br class="">And wondering if (expecting that) you think the same logic applies.<br class=""><br class="">I make no claim as to optimality, which seems to be what you are getting at.<br class=""><br class="">Are you saying the post I am citing is incorrect ?<br class="">Or that I misunderstood it ?<br class="">Or could it be that you misread my email ?<br class=""><br class=""><br class=""><br class="">Yes I am hoping *Nuno* can come up with a better example. There is a claim<br class="">that “branch on poison is undefined behavior” is the right definition, which is<br class="">not justified in the Paper [2], which John is waffling on, which no one seems to<br class="">be able to justify, and which gives the appearance at least of flying in the face<br class="">of common sense.<br class=""><br class="">This is the IR definition we’re talking about here, the literal heart and soul of<br class="">the compiler, everyone should be at least a little bit concerned.<br class=""><br class=""><br class="">Peter Lawrence.<br class=""><br class=""><br class="">[1. I’m having difficulty locating the post, here’s one that is similar<br class=""><br class=""><span class="Apple-tab-span" style="white-space: pre;"> </span>Tue Jul 22, 2014 “On semantics of add instruction - nsw, nuw”<br class=""><br class=""> It also occurs to me that the more detailed post I am remembering but<br class=""> can’t find might have been about SCEV rather than GVN ]<br class=""><br class=""><br class="">[2. “Taming undefined behavior in LLVM” ]<br class=""><br class=""><br class=""><br class=""><br class=""><br class=""><blockquote type="cite" class="">On Jun 14, 2017, at 2:12 PM, Daniel Berlin <<a href="mailto:dberlin@dberlin.org" class="">dberlin@dberlin.org</a>> wrote:<br class=""><br class=""><br class=""><br class="">On Wed, Jun 14, 2017 at 1:26 PM, Peter Lawrence via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a><span class="Apple-converted-space"> </span><<a href="mailto:llvm-dev@lists.llvm.org" class="">mailto:llvm-dev@lists.llvm.org</a>>> wrote:<br class=""><br class="">1. —————<br class="">Dan,<br class=""> The reasoning given below for how GVN operates seems odd to me,<br class=""><br class="">Poison is an attribute of a value, just like nsw is an attribute of an operation,<br class=""><br class="">So when GVN sees a pair of equal values, one of which has an extra attribute,<br class="">The proper choice for representative value is the one without the attribute,<br class=""><br class="">There are many many choices of what make *good* representative values in NewGVN.<br class="">I would deny any assertion that there is a proper choice, and that if there is one, it must be what you suggest :)<br class="">You actually can prove that there is no optimal such choice. Different choices will lead you to discover different congruences in any practical algorithms, even complete ones (as the issues here are orthogonal to herbrand equivalence., and instead related to inference of facts from control flow and other things, as well as what the results from symbolic evaluation and simplification)<br class="">There are examples in the paper cited by newgvn of situations where different choices of values for predicate and phi inference will enable you to discover different congruences.<br class=""><br class="">More importantly, given the other purpose of the representatives is to be used during simplification and symbolic evaluation, something we know we *cannot* possibly be optimal at, i do not believe you can assert that there is such an easily knowable best representative.<br class=""><br class="">There is also no representation we could pick that would avoid all issues for others<br class=""><br class=""><br class=""><br class="">Thoughts ?<br class="">Comments ?<br class="">Questions ?<br class=""><br class="">The middle one.<br class=""><br class="">I'm going to be frank and honest:<br class="">I don't feel like i have a good understanding of what your goal here is, or what you see your role as.<br class="">I can tell you, again, completely personally, that i find your approach off-putting at times.<br class="">To give a concrete example, here, what i see (again, from *my* perspective), is you are asserting things to me and asking me to confirm them or disprove them. I generally have not found this to be a good collaborative approach to increasing understanding. You then say"If Dan agrees with the above then can we come up with a better example". In practice, so far, that has meant "can *Nuno* come up with a better example" (IE the we seems to be turning into work for others).<br class=""><br class="">I do not say this as a true complaint so much as a explanation of why i don't feel like i understand your perspective on things, and i think it would be helpful for me to be able to.<br class="">I also certainly do not claim that there are not multiple ways to approach problem solving, communities, etc, or that what I or anyone else does is best.</blockquote></blockquote></div></blockquote></div><br class=""></div></body></html>