]> git.ipfire.org Git - thirdparty/glibc.git/commit - ChangeLog
[powerpc] SET_RESTORE_ROUND optimizations and bug fix
authorPaul A. Clarke <pc@us.ibm.com>
Thu, 19 Sep 2019 13:35:16 +0000 (08:35 -0500)
committerPaul A. Clarke <pc@us.ibm.com>
Thu, 19 Sep 2019 18:02:30 +0000 (13:02 -0500)
commitf1c56cdff09f650ad721fae026eb6a3651631f3d
treeb06f5014ae1899707cfb059eb9fba3da79877e9e
parent64fab3633aecc8eadc1338aa8953f8b2f37e3ebf
[powerpc] SET_RESTORE_ROUND optimizations and bug fix

SET_RESTORE_ROUND brackets a block of code, temporarily setting and
restoring the rounding mode and letting everything else, including
exceptions generated within the block, pass through.

On powerpc, the current code clears the exception enables, which will hide
exceptions generated within the block.  This issue was introduced by me
in commit e905212627350d54b58426214b5a54ddc852b0c9.

Fix this by not clearing exception enable bits in the prologue.

Also, since we are no longer changing the enable bits in either the
prologue or the epilogue, there is no need to test for entering/exiting
non-stop mode.

Also, optimize the prologue get/save/set rounding mode operations for
POWER9 and later by using 'mffscrn' when possible.

Suggested-by: Paul E. Murphy <murphyp@linux.ibm.com>
Reviewed-by: Paul E. Murphy <murphyp@linux.ibm.com>
Fixes: e905212627350d54b58426214b5a54ddc852b0c9
2019-09-19  Paul A. Clarke  <pc@us.ibm.com>

* sysdeps/powerpc/fpu/fenv_libc.h (fegetenv_and_set_rn): New.
(__fe_mffscrn): New.
* sysdeps/powerpc/fpu/fenv_private.h (libc_feholdsetround_ppc_ctx):
Do not clear enable bits, remove obsolete code, use
fegetenv_and_set_rn.
(libc_feresetround_ppc): Remove obsolete code, use
fegetenv_and_set_rn.
ChangeLog
sysdeps/powerpc/fpu/fenv_libc.h
sysdeps/powerpc/fpu/fenv_private.h