<div dir="ltr"><div dir="ltr"><div class="gmail_default" style="font-family:verdana,sans-serif"><br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Aug 1, 2019 at 11:35 AM Mekhanoshin, Stanislav <<a href="mailto:Stanislav.Mekhanoshin@amd.com">Stanislav.Mekhanoshin@amd.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">



<div style="text-align:left;direction:ltr">
<div>The problem is that is fixes compiler crash, correctness was always before performance right?</div></div></blockquote><div><br></div><div><div class="gmail_default" style="font-family:verdana,sans-serif">Agreed. </div></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div style="text-align:left;direction:ltr">
<div>Can you bear with me for few more hours?</div></div></blockquote><div><br></div><div><div class="gmail_default" style="font-family:verdana,sans-serif">Sure. </div><div class="gmail_default" style="font-family:verdana,sans-serif"><span style="font-family:Arial,Helvetica,sans-serif"><br></span></div><div class="gmail_default" style="font-family:verdana,sans-serif"><span style="font-family:Arial,Helvetica,sans-serif">--Artem</span></div><div class="gmail_default" style="font-family:verdana,sans-serif"><span style="font-family:Arial,Helvetica,sans-serif"> </span><br></div></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div style="text-align:left;direction:ltr">
<div><br>
</div>
<div><span>
<pre>-- <br></pre>
<div style="width:71ch">Stas</div>
</span></div>
<div><br>
</div>
<div>-----Original Message-----</div>
<div><b>From</b>: Artem Belevich <<a href="mailto:Artem%20Belevich%20%3ctra@google.com%3e" target="_blank">tra@google.com</a>></div>
<div><b>To</b>: "Mekhanoshin, Stanislav" <<a href="mailto:%22Mekhanoshin,%20Stanislav%22%20%3cStanislav.Mekhanoshin@amd.com%3e" target="_blank">Stanislav.Mekhanoshin@amd.com</a>></div>
<div><b>Cc</b>: "Arsenault, Matthew" <<a href="mailto:%22Arsenault,%20Matthew%22%20%3cMatthew.Arsenault@amd.com%3e" target="_blank">Matthew.Arsenault@amd.com</a>>, <a href="mailto:benny.kra@gmail.com" target="_blank">benny.kra@gmail.com</a> <<a href="mailto:%22benny.kra@gmail.com%22%20%3cbenny.kra@gmail.com%3e" target="_blank">benny.kra@gmail.com</a>>,
 <a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a> <<a href="mailto:%22llvm-commits@lists.llvm.org%22%20%3cllvm-commits@lists.llvm.org%3e" target="_blank">llvm-commits@lists.llvm.org</a>></div>
<div><b>Subject</b>: Re: [llvm] r367443 - [AMDGPU] Fix for vectorizer crash with pointers of different size</div>
<div><b>Date</b>: Thu, 01 Aug 2019 11:33:35 -0700</div>
<div><br>
</div>
[CAUTION: External Email]
<div>
<div dir="ltr">
<div style="font-family:verdana,sans-serif">Can you revert the change while you're looking for a better solution? This patch has a noticeable negative impact on performance of GPU code we use.</div>
<div style="font-family:verdana,sans-serif"><br>
</div>
<div style="font-family:verdana,sans-serif">Thank you,</div>
<div style="font-family:verdana,sans-serif">--Artem</div>
</div>
<br>
<div class="gmail_quote">
<div dir="ltr" class="gmail_attr">On Thu, Aug 1, 2019 at 11:14 AM Mekhanoshin, Stanislav via llvm-commits <<a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a>> wrote:<br>
</div>
<blockquote type="cite" style="margin:0px 0px 0px 0.8ex;border-left:2px solid rgb(114,159,207);padding-left:1ex">
<div style="text-align:left;direction:ltr">
<div>In your case search ends before pointers change address space. They all come to the same root casted pointer "%alloc16 = addrspacecast i8* %alloc1 to i8 addrspace(1)*". In the failing case which was fixed one of the pointers has addrspacecast stripped
 while the search was still in progress, which has caused the problem.</div>
<div><br>
</div>
<div>I am looking if I can find a better cutoff criteria. Size is one of such possible criteria, but I want to look into this a little more.</div>
<div><span><br>
<pre>-- </pre>
<br>
<div style="width:71ch">Stas</div>
</span></div>
<div><br>
</div>
<div>-----Original Message-----</div>
<div><b>From</b>: Benjamin Kramer <<a href="mailto:Benjamin%20Kramer%20%3cbenny.kra@gmail.com%3e" target="_blank">benny.kra@gmail.com</a>></div>
<div><b>To</b>: "Arsenault, Matthew" <<a href="mailto:%22Arsenault,%20Matthew%22%20%3cMatthew.Arsenault@amd.com%3e" target="_blank">Matthew.Arsenault@amd.com</a>></div>
<div><b>Cc</b>: "Mekhanoshin, Stanislav" <<a href="mailto:%22Mekhanoshin,%20Stanislav%22%20%3cStanislav.Mekhanoshin@amd.com%3e" target="_blank">Stanislav.Mekhanoshin@amd.com</a>>, llvm-commits <<a href="mailto:llvm-commits%20%3cllvm-commits@lists.llvm.org%3e" target="_blank">llvm-commits@lists.llvm.org</a>></div>
<div><b>Subject</b>: Re: [llvm] r367443 - [AMDGPU] Fix for vectorizer crash with pointers of different size</div>
<div><b>Date</b>: Thu, 01 Aug 2019 16:53:43 +0200</div>
<div><br>
</div>
[CAUTION: External Email]
<div>
<div dir="ltr">Currently not at my workstation, attached is a test case that I scraped from the logs. This should have a <4 x float> load & store and scalar arithmetic after going through LoadStoreVectorizer.</div>
<br>
<div class="gmail_quote">
<div dir="ltr" class="gmail_attr">On Thu, Aug 1, 2019 at 3:14 PM Arsenault, Matthew <<a href="mailto:Matthew.Arsenault@amd.com" target="_blank">Matthew.Arsenault@amd.com</a>> wrote:<br>
</div>
<blockquote type="cite" style="margin:0px 0px 0px 0.8ex;border-left:2px solid rgb(114,159,207);padding-left:1ex">
<div>
<div style="direction:ltr">
<div>
<div></div>
</div>
<div><br>
</div>
<div class="gmail-m_-8536938154835411154gmail-m_582981732653834203gmail-m_2635103100846164712ms-outlook-ios-signature">
</div>
</div>
<div>
<div dir="ltr">
<div class="gmail_quote">
<blockquote type="cite" style="margin:0px 0px 0px 0.8ex;border-left:2px solid rgb(114,159,207);padding-left:1ex">
<br>
<br>
</blockquote>
<div><br>
</div>
<div>This is too aggressive, it will prevent any pointer pair that's addrspacecast'ed from ever being recognized as consecutive. What's the reason for not checking the size? I'm seeing regressions where pointers are getting loaded from memory and then casted
 to the right addresspace.</div>
<div><br>
</div>
<div>- Ben</div>
<div> </div>
<div style="direction:ltr">Do you have an example where this matters? I would expect any cases that are vectorizable and involve an addrspacecast would be taken care of by InferAddressSpaces, so the vectorizer doesn’t need to worry about them.</div>
</div>
</div>
</div>
</div>
<br>
</blockquote>
</div>
</div>
</div>
_______________________________________________<br>
llvm-commits mailing list<br>
<a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a><br>
<a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits" rel="noreferrer" target="_blank">https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits</a><br>
<br>
</blockquote>
</div>
<br clear="all">
<div><br>
</div>
</div>
</div>

</blockquote></div><br clear="all"><div><br></div>-- <br><div dir="ltr" class="gmail_signature"><div dir="ltr">--Artem Belevich</div></div></div>