<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;"><br><div><blockquote type="cite"><div>On Jul 17, 2014, at 2:44 PM, Chandler Carruth <<a href="mailto:chandlerc@google.com">chandlerc@google.com</a>> wrote:</div><br class="Apple-interchange-newline"><div><blockquote class="gmail_quote" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: 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; margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-color: rgb(204, 204, 204); border-left-style: solid; padding-left: 1ex;">I worry about the maintenance cost of this in the optimizer.</blockquote><div style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: 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;"><br></div><div style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: 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;">As long as we don't go "crazy" trying to recover the performance, it should be OK. Hal has already put together the patches needed for his current approach. We'll likely have to tweak this approach a little, but we don't need to go throguh and change every single hasOneUse() check to do something special with these invariants (or assumptions). </div></div></blockquote></div><br><div>My main concern was the impact on use-list iteration and hasOneUse() patterns, and the potential burden on the rest of the optimizer because we often need to check for ephemeral values. Is there any way to check that a use is ephemeral? The potential for silently defeating optimizations when you add the intrinsics is also worrisome. It could lead to surprising results when someone adds a new invariant that is supposed to improve performance.</div><div><br></div><div>That said, I put a lot of weight in having an implementation. If you can run experiments where you add a significant number of invariants and don’t see performance regressions, then I’d be convinced. If we can make it work in the current code base, then maintaining it should be doable.</div><div><br></div><div>It could also be a problem that we introduce a call that potentially writes memory, but that is less subtle than the use-list problem.</div><div><br></div><div>On all the other points raised in the thread, I agree with Chandler and Philip’s comments.</div><div><br></div><div>-Andy</div></body></html>