<div dir="ltr">Test case added in r289374.</div><div class="gmail_extra"><br clear="all"><div><div class="gmail_signature" data-smartmail="gmail_signature">~Craig</div></div>
<br><div class="gmail_quote">On Sun, Dec 11, 2016 at 12:01 AM, Chandler Carruth <span dir="ltr"><<a href="mailto:chandlerc@google.com" target="_blank">chandlerc@google.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">No test case?</div><div class="HOEnZb"><div class="h5"><br><div class="gmail_quote"><div dir="ltr">On Sat, Dec 10, 2016 at 11:52 PM Craig Topper via llvm-commits <<a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Author: ctopper<br class="m_1490807086470206452gmail_msg">
Date: Sun Dec 11 01:42:04 2016<br class="m_1490807086470206452gmail_msg">
New Revision: 289371<br class="m_1490807086470206452gmail_msg">
<br class="m_1490807086470206452gmail_msg">
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=289371&view=rev" rel="noreferrer" class="m_1490807086470206452gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project?rev=289371&view=rev</a><br class="m_1490807086470206452gmail_msg">
Log:<br class="m_1490807086470206452gmail_msg">
[AVX-512][InstCombine] Teach InstCombineCalls how to simplify demanded for scalar cmp intrinsics with masking and rounding.<br class="m_1490807086470206452gmail_msg">
<br class="m_1490807086470206452gmail_msg">
These intrinsics don't read the upper elements of their first and second input. These are slightly different the the SSE version which does use the upper bits of its first element as passthru bits since the result goes to an XMM register. For AVX-512 the result goes to a mask register instead.<br class="m_1490807086470206452gmail_msg">
<br class="m_1490807086470206452gmail_msg">
Modified:<br class="m_1490807086470206452gmail_msg">
llvm/trunk/lib/Transforms/<wbr>InstCombine/InstCombineCalls.<wbr>cpp<br class="m_1490807086470206452gmail_msg">
<br class="m_1490807086470206452gmail_msg">
Modified: llvm/trunk/lib/Transforms/<wbr>InstCombine/InstCombineCalls.<wbr>cpp<br class="m_1490807086470206452gmail_msg">
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/InstCombine/InstCombineCalls.cpp?rev=289371&r1=289370&r2=289371&view=diff" rel="noreferrer" class="m_1490807086470206452gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/llvm/trunk/lib/<wbr>Transforms/InstCombine/<wbr>InstCombineCalls.cpp?rev=<wbr>289371&r1=289370&r2=289371&<wbr>view=diff</a><br class="m_1490807086470206452gmail_msg">
==============================<wbr>==============================<wbr>==================<br class="m_1490807086470206452gmail_msg">
--- llvm/trunk/lib/Transforms/<wbr>InstCombine/InstCombineCalls.<wbr>cpp (original)<br class="m_1490807086470206452gmail_msg">
+++ llvm/trunk/lib/Transforms/<wbr>InstCombine/InstCombineCalls.<wbr>cpp Sun Dec 11 01:42:04 2016<br class="m_1490807086470206452gmail_msg">
@@ -1738,7 +1738,9 @@ Instruction *InstCombiner::visitCallInst<br class="m_1490807086470206452gmail_msg">
case Intrinsic::x86_sse2_ucomigt_<wbr>sd:<br class="m_1490807086470206452gmail_msg">
case Intrinsic::x86_sse2_ucomile_<wbr>sd:<br class="m_1490807086470206452gmail_msg">
case Intrinsic::x86_sse2_ucomilt_<wbr>sd:<br class="m_1490807086470206452gmail_msg">
- case Intrinsic::x86_sse2_ucomineq_<wbr>sd: {<br class="m_1490807086470206452gmail_msg">
+ case Intrinsic::x86_sse2_ucomineq_<wbr>sd:<br class="m_1490807086470206452gmail_msg">
+ case Intrinsic::x86_avx512_mask_<wbr>cmp_ss:<br class="m_1490807086470206452gmail_msg">
+ case Intrinsic::x86_avx512_mask_<wbr>cmp_sd: {<br class="m_1490807086470206452gmail_msg">
// These intrinsics only demand the 0th element of their input vectors. If<br class="m_1490807086470206452gmail_msg">
// we can simplify the input based on that, do so now.<br class="m_1490807086470206452gmail_msg">
bool MadeChange = false;<br class="m_1490807086470206452gmail_msg">
<br class="m_1490807086470206452gmail_msg">
<br class="m_1490807086470206452gmail_msg">
______________________________<wbr>_________________<br class="m_1490807086470206452gmail_msg">
llvm-commits mailing list<br class="m_1490807086470206452gmail_msg">
<a href="mailto:llvm-commits@lists.llvm.org" class="m_1490807086470206452gmail_msg" target="_blank">llvm-commits@lists.llvm.org</a><br class="m_1490807086470206452gmail_msg">
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits" rel="noreferrer" class="m_1490807086470206452gmail_msg" target="_blank">http://lists.llvm.org/cgi-bin/<wbr>mailman/listinfo/llvm-commits</a><br class="m_1490807086470206452gmail_msg">
</blockquote></div>
</div></div></blockquote></div><br></div>