<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Nov 16, 2016 at 5:29 AM, Patrick Boettcher 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">Hi,<br>
<br>
in section B.29. (Write State Register Instructions) of 'The SPARC<br>
Architecture Manual Version 8' it is said that the "The write state<br>
register instructions are delayed-write instructions."<br>
<br>
The Y-register is a state-register.<br>
<br>
Furthermore in the B.29-secion there is a programming note saying:<br>
<br>
MULScc, RDY, SDIV, SDIVcc, UDIV, and UDIVcc implicitly read the Y<br>
register. If any of these instructions execute within three<br>
instructions after a WRY which changed the contents of the Y<br>
register, its results are undefined.<br>
<br>
This currently is not respected with LLVM. I'm using 3.9 and checked<br>
whether any commit on the master-branch handles this case, I haven't<br>
seen anything - but I might be wrong.<br></blockquote><div> </div><div>Yep, this definitely isn't done. However, it appears that on the hardware I've looked at, it didn't appear to actually be necessary (as one might expect from sane hardware...), so I'd not gotten around to fixing it.</div><div><br></div><div>Are you looking at this because you have a program which is mis-executing on some hardware you have, or just because you were looking at the assembly output and noticed the spec non-compliance?</div></div></div></div>