<br><br><div class="gmail_quote">On Fri Jan 16 2015 at 1:57:34 PM Fiona Glaser <<a href="mailto:fglaser@apple.com">fglaser@apple.com</a>> 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"><div>> 1. Run your patch through clang-format please. The patch does not follow the LLVM formatting guidelines.</div><div><br></div></div><div style="word-wrap:break-word"><div>Done, and changed per Mehdi’s suggestions.</div></div><div style="word-wrap:break-word"><div><br></div><div>> 2. What is the impact of this on arm64 and armv7s generated code? Although the approach makes sense to me, I want to be sure we do not degrade other targets. Note that I do not expect you to run tests if you cannot :).</div><div><br></div></div><div style="word-wrap:break-word"><div>I don’t think it should even affect any target that doesn’t have canonical vector sizes of both N and 2*N, for a data type of N/2 or smaller. Otherwise the case this patch targets can’t come up.</div><div></div></div><div style="word-wrap:break-word"><div><br><blockquote type="cite"><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:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px"><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">3. What are the runtime performance impact on x86_64, with and without -mavx2?<br></blockquote></div></blockquote><div><br></div></div></div><div style="word-wrap:break-word"><div><div>I’m not sure in general; this affects a few very specific vector constructs that were being pessimized.</div></div></div><div style="word-wrap:break-word"><div><br><blockquote type="cite"><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:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px"><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">4. Add a run line for avx  too:<br>+; RUN: llc < %s -march=x86-64 -mattr=+avx2 | FileCheck %s<br></blockquote></div></blockquote><div><br></div></div></div><div style="word-wrap:break-word"><div><div>Done.</div></div></div><div style="word-wrap:break-word"><div><div><br></div><blockquote type="cite"><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:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px"><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">5. Should we use a triple instead of march?</blockquote></div></blockquote><div><br></div></div></div><div style="word-wrap:break-word"><div>Do triples let you specify particular attributes (AVX, etc?)</div></div></blockquote><div><br></div><div>Not for sorta. It depends on if it's been hacked into the triple (i.e. darwin x86_64h) or set as the default for an operating system. But in this case I think just x86_64 and -mattr is the right way to go here.</div><div><br></div><div>-eric </div></div>