<div dir="ltr"><div>Sounds like the select lowering issue is definitely separate from the FENV work.<br><br>Is there a bug report with a C or IR example? You want to generate compare and branch instead of a cmov for something like this?<br></div><br>int foo(float x) {<br>  if (x < 42.0f)<br>    return x;<br>  return 12;<br>}<br><br>define i32 @foo(float %x) {<br>  %cmp = fcmp olt float %x, 4.200000e+01<br>  %conv = fptosi float %x to i32<br>  %ret = select i1 %cmp, i32 %conv, i32 12<br>  ret i32 %ret<br>}<br><br>$ clang -O2 cmovfp.c -S -o -<br>    movss    LCPI0_0(%rip), %xmm1    ## xmm1 = mem[0],zero,zero,zero<br>    ucomiss    %xmm0, %xmm1<br>    cvttss2si    %xmm0, %ecx<br>    movl    $12, %eax<br>    cmoval    %ecx, %eax<br>    retq<br><br><br></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, May 11, 2017 at 1:28 PM, Kaylor, Andrew via llvm-dev <span dir="ltr"><<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">





<div link="blue" vlink="purple" lang="EN-US">
<div class="m_5149843639143109846WordSection1">
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;color:#1f497d">Hi Michael,<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;color:#1f497d"><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;color:#1f497d">To be honest I haven’t started working on FP to integer conversions for FENV_ACCESS yet.<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;color:#1f497d"><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;color:#1f497d">To some extent I would consider the issue that you found independent of what I’m doing to constrain FP behavior.  That is, I think we ought to make the change
 you’re asking for even apart from the FENV_ACCESS work.  When I get to the conversions for FENV_ACCESS support it may require some additional constraints, but I think if the branching conversion is usually faster (and it looks like it will be) then that should
 be the default behavior.<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;color:#1f497d"><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;color:#1f497d">I’ll try to look into that.  I’d offer to give you advice on putting together a patch, but I’m still learning my way around the ISel code myself.  I think I know
 enough to figure out what to do but not enough to tell someone else how to do it without a bunch of wrong turns.<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;color:#1f497d"><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;color:#1f497d">-Andy<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;color:#1f497d"><u></u> <u></u></span></p>
<p class="MsoNormal"><a name="m_5149843639143109846__MailEndCompose"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;color:#1f497d"><u></u> <u></u></span></a></p>
<div>
<div style="border:none;border-top:solid #e1e1e1 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal"><a name="m_5149843639143109846______replyseparator"></a><b><span style="font-size:11.0pt;font-family:"Calibri",sans-serif">From:</span></b><span style="font-size:11.0pt;font-family:"Calibri",sans-serif"> Michael Clark [mailto:<a href="mailto:michaeljclark@mac.com" target="_blank">michaeljclark@mac.com</a>]
<br>
<b>Sent:</b> Wednesday, May 10, 2017 7:59 PM<br>
<b>To:</b> Kaylor, Andrew <<a href="mailto:andrew.kaylor@intel.com" target="_blank">andrew.kaylor@intel.com</a>><br>
<b>Cc:</b> llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>><br>
<b>Subject:</b> FENV_ACCESS and floating point LibFunc calls<u></u><u></u></span></p>
</div>
</div><div><div class="h5">
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">Hi Andy,<u></u><u></u></p>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">I’m interested to try out your patches…<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">I understand the scope of FENV_ACCESS is relatively wide, however I’m still curious if you managed to figure out how to prevent the SelectionDAGLegalize::<wbr>ExpandNode() FP_TO_UINT lowering of the FPToUI intrinsic from producing the predicate
 logic that incorrectly sets the floating point accrued exceptions due to unconditional execution of the ISD::FSUB node attached to the SELECT node. It’s a little above my head to try to solve this issue with my current understanding of LLVM but I could give
 it a try. I’d need some guidance as to how the lowering of SELECT can be controlled. i.e. where LLVM decides whether and how to lower a select node as a branch vs predicate logic.<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">I’d almost forgotten that we microbenchmarked this and found the branching version is faster with regular input (< LLONG_MAX).<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal" style="margin-bottom:12.0pt">- <a href="https://godbolt.org/g/ytgk7l" target="_blank">https://godbolt.org/g/ytgk7l</a><u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">All, Where does LLVM decide to lower select as predicate logic vs branches and how does the cost model work? I’m curious about a tuning flag to generate branches instead of computing both values and using conditional moves…<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">Best,<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">Michael.<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<div>
<blockquote style="margin-top:5.0pt;margin-bottom:5.0pt">
<div>
<p class="MsoNormal">On 11 May 2017, at 11:41 AM, via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<u></u><u></u></p>
</div>
<p class="MsoNormal"><u></u> <u></u></p>
<div>
<p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Helvetica",sans-serif">Hi all,<br>
<br>
Background<br>
I've been working on adding the necessary support to LLVM for clang to be able to support the STDC FENV_ACCESS pragma, which basically allows users to modify rounding mode at runtime and depend on the value of floating-point status flags or to unmask floating
 point exceptions without unexpected side effects.  I've committed an initial patch (r293226) that adds constrained intrinsics for the basic FP operations, and I have a patch up for review now (</span><a href="https://reviews.llvm.org/D32319" target="_blank"><span style="font-size:9.0pt;font-family:"Helvetica",sans-serif">https://reviews.llvm.org/<wbr>D32319</span></a><span style="font-size:9.0pt;font-family:"Helvetica",sans-serif">)
 that adds constrained versions of a number of libm-like FP intrinsics.<br>
<br>
Current problem<br>
Now I'm trying to make sure I have a good solution for the way in which the optimizer handles recognized calls to libm functions (sqrt, pow, cos, sin, etc.).  Basically, I need to prevent all passes from making any modifications to these calls that would make
 assumptions about rounding mode or improperly affect the FP status flags (either suppressing flags that should be present or setting flags that should not be set).  For instance, there are circumstances in which the optimizer will constant fold a call to one
 of these functions if the value of the arguments are known at compile time, but this constant folding generally assumes the default rounding mode and if the library call would have set a status flag, I need the flag to be set.<br>
<br>
Question<br>
My question is, can/should I just rely on the front end setting the "nobuiltin" attribute for the call site in any location where the FP behavior needs to be restricted?<br>
<br>
Ideally, I would like to be able to conditionally enable optimizations like constant folding if I am able to prove that the rounding mode, though dynamic, is known for the callsite at compile time (the constrained intrinsics have a mechanism to enable this),
 but at the moment I am more concerned about correctness and would be willing to sacrifice optimizations to get correct behavior.  Long term, I was thinking that maybe I could do something like attach metadata to indicate rounding mode and exception behavior
 when they were known.<br>
<br>
Is there a better way to do this?<br>
<br>
Thanks,<br>
Andy</span><u></u><u></u></p>
</div>
</blockquote>
</div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
</div></div></div>
</div>

<br>______________________________<wbr>_________________<br>
LLVM Developers mailing list<br>
<a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/<wbr>mailman/listinfo/llvm-dev</a><br>
<br></blockquote></div><br></div>