<div dir="ltr">Thanks, Matt, that's good to know. If we only consider immediates that are not modified by optimization passes, perhaps the problem is more tractable. In my brief exploration, it appeared that the custom NaN payloads of the immediates were intact up until that conversion in the MC layer.</div><br><div class="gmail_quote"><div dir="ltr">On Fri, Nov 9, 2018 at 2:10 PM Arsenault, Matthew <<a href="mailto:Matthew.Arsenault@amd.com">Matthew.Arsenault@amd.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">




<div dir="ltr">
<div id="m_-164387003029783879divtagdefaultwrapper" style="font-size:12pt;color:#000000;font-family:Calibri,Helvetica,sans-serif" dir="ltr">
<p style="margin-top:0;margin-bottom:0">One issue is that currently none (except one I think I added) of the functions in APFloat properly preserve payload bits so I think the problem is bigger than late corruption if you are expecting these to behave as expected.</p>
<p style="margin-top:0;margin-bottom:0"><br>
</p>
<p style="margin-top:0;margin-bottom:0">-Matt</p>
</div>
<hr style="display:inline-block;width:98%">
<div id="m_-164387003029783879divRplyFwdMsg" dir="ltr"><font face="Calibri, sans-serif" style="font-size:11pt" color="#000000"><b>From:</b> llvm-dev <<a href="mailto:llvm-dev-bounces@lists.llvm.org" target="_blank">llvm-dev-bounces@lists.llvm.org</a>> on behalf of Thomas Lively via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>><br>
<b>Sent:</b> Friday, November 9, 2018 2:04:11 PM<br>
<b>To:</b> <a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a><br>
<b>Subject:</b> [llvm-dev] Should NaN payloads be preserved through compilation?</font>
<div> </div>
</div>
<div>
<div dir="ltr">
<div dir="ltr">Hi everyone,
<div><br>
</div>
<div>The WebAssembly backend recently had <a href="https://bugs.llvm.org/show_bug.cgi?id=39448" target="_blank">
Bug 39448</a> filed against it because NaN payloads in floating-point immediates are not preserved through compilation on 32-bit builds. I took a look and the corruption takes place when the immediates are converted from APFloats to be stored as native doubles
 in MCOperand. I assume this bug only appears in 32-bit builds because they are using x87 doubles that happen to not preserve all possible NaN payloads.</div>
<div><br>
</div>
<div>There are two things we could do here: Change MCOperand to not store floating point immediates as native doubles, or explicitly accept that NaN payloads in immediates will not necessarily be preserved through compilation.</div>
<div><br>
</div>
<div>The ability to have custom NaN payloads in immediates could be useful to the WebAssembly community, but if the consensus is that LLVM should not guarantee their preservation, that's fine too. What do you think?</div>
<div><br>
</div>
<div>Thomas</div>
</div>
</div>
</div>
</div>

</blockquote></div>