Page MenuHomeFreeBSD

Save all fpcr/fpsr bits in the AArch64 fenv_t
ClosedPublic

Authored by arichardson on Mar 9 2021, 8:02 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 11, 11:59 AM
Unknown Object (File)
Sat, Jan 11, 8:55 AM
Unknown Object (File)
Nov 19 2024, 2:04 AM
Unknown Object (File)
Nov 13 2024, 9:17 PM
Unknown Object (File)
Oct 19 2024, 5:51 AM
Unknown Object (File)
Oct 19 2024, 5:51 AM
Unknown Object (File)
Oct 19 2024, 5:51 AM
Unknown Object (File)
Oct 19 2024, 5:31 AM
Subscribers

Details

Summary

The existing code masked off all bits that it didn't know about. To be
future-proof, we should save and restore the entire fpcr/fpsr registers.
Additionally, the existing fesetenv() was incorrectly setting the rounding
mode in fpsr instead of fpcr.

This patch stores fpcr in the high 32 bits of fenv_t and fpsr in the low
bits instead of trying to interleave them in a single 32-bit field.

Technically, this is an ABI break if you re-compile parts of your code or
pass a fenv_t between DSOs that were compiled with different versions
of fenv.h. However, I believe we should fix this since the existing code
was broken and passing fenv_t across DSOs should rarely happen.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 37704
Build 34593: arc lint + arc unit

Event Timeline

I think this level of ABI breakage probably is ok. At least the size of the type hasn't changed.

This revision is now accepted and ready to land.Mar 11 2021, 1:57 PM