<html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"></head><body dir="auto"><div style="-webkit-text-size-adjust: auto;"><br></div><div style="-webkit-text-size-adjust: auto;">On Nov 5, 2013, at 11:51 AM, Andrew Trick <<a href="mailto:atrick@apple.com">atrick@apple.com</a>> wrote:<br><br></div><blockquote type="cite" style="-webkit-text-size-adjust: auto;"><div><meta http-equiv="Content-Type" content="text/html charset=windows-1252"><br><div><div>On Nov 5, 2013, at 11:42 AM, Renato Golin <<a href="mailto:renato.golin@linaro.org">renato.golin@linaro.org</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div dir="ltr">On 2 November 2013 05:59, Hal Finkel <span dir="ltr"><<a href="mailto:hfinkel@anl.gov" target="_blank">hfinkel@anl.gov</a>></span> wrote:<br><div class="gmail_extra"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div class="HOEnZb"><div class="h5">> I would be scared to enable SCEV AA because it's not well tested<br>
<br>
</div></div>This seems like a solvable problem. SCEV AA itself is something like 30 lines of non-boilerplate code, and essentially does one thing (calls getMinusSCEV in both directions and uses getUnsignedRange on the result). We should look it over.<br>
</blockquote><div></div></div><br></div><div class="gmail_extra">If SCEV AA itself is conservative, the worst that can happen is that it won't detect all cases it could, but we can extend it later. It seems to me that this piece of code was added as an experiment and never updated, but since it's already there, we could come up with a few tests that would check the boundaries of a 30 loc piece, no?</div>
</div></blockquote><br></div><div>Yes SCEV AA was an experiment. The reason it wasn’t ripped out is that it’s potentially useful. The worst that will happen is that passes will crash in *very* confusing ways. SCEVs will be evaluated early, not properly updated, and someone will try to expand them. You won’t hit this problems with simple testing.</div><div><br></div><div>I’m not opposed to making SCEV AA a reliable thing, but I’m not sure what “fundamental problems” we’ll hit along the way.</div><div><br></div><div>My primary objection is that I don’t think SCEV should run before the LICM loop pass manager. It’s to expensive in terms of compile time and does have maintenance burden. I’m not yet aware of any long-term need to have SCEV running at this point. If we’re only talking about disambiguating constant array indices with loop variant ones with constant bounds, there might be a simpler way to handle it.</div></div></blockquote><div style="-webkit-text-size-adjust: auto;"><br></div><span style="-webkit-text-size-adjust: auto;">...that said. If SCEV AA is much simpler, and we are confident that it will be invalidated before anything else uses it. (InstCombine may do it), then it's a straightforward compile time vs perf trade off. That can be measured. </span><div><span style="-webkit-text-size-adjust: auto;"><br></span></div><div><span style="-webkit-text-size-adjust: auto;">Andy<br></span><div><br><blockquote type="cite" style="-webkit-text-size-adjust: auto;"><div><div><br></div><div>-Andy</div><br></div></blockquote><blockquote type="cite" style="-webkit-text-size-adjust: auto;"><div><span>_______________________________________________</span><br><span>LLVM Developers mailing list</span><br><span><a href="mailto:LLVMdev@cs.uiuc.edu">LLVMdev@cs.uiuc.edu</a>         <a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a></span><br><span><a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev">http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev</a></span><br></div></blockquote></div></div></body></html>