diff options
author | Paul A. Clarke <pc@us.ibm.com> | 2019-07-12 20:13:58 -0500 |
---|---|---|
committer | Paul A. Clarke <pc@us.ibm.com> | 2019-08-28 13:49:19 -0500 |
commit | cd7ce12a027656ad3cda774454088de5a2c7fbfa (patch) | |
tree | ae1686c96b9c3e627df3123eaa6f329db5a5b174 /ChangeLog | |
parent | 35ffd20dbd76d3cb6b478c7a69bb40d8c827ed81 (diff) | |
download | glibc-cd7ce12a027656ad3cda774454088de5a2c7fbfa.tar.gz glibc-cd7ce12a027656ad3cda774454088de5a2c7fbfa.tar.xz glibc-cd7ce12a027656ad3cda774454088de5a2c7fbfa.zip |
[powerpc] fe{en,dis}ableexcept optimize bit translations
The exceptions passed to fe{en,dis}ableexcept() are defined in the ABI as a bitmask, a combination of FE_INVALID, FE_OVERFLOW, etc. Within the functions, these bits must be translated to/from the corresponding enable bits in the Floating Point Status Control Register (FPSCR). This translation is currently done bit-by-bit. The compiler generates a series of conditional bit operations. Nicely, the "FE" exception bits are all a uniform offset from the FPSCR enable bits, so the bit-by-bit operation can instead be performed by a shift with appropriate masking.
Diffstat (limited to 'ChangeLog')
-rw-r--r-- | ChangeLog | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog index 37c2ff3280..c2d70717ec 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,12 @@ +2019-08-28 Paul A. Clarke <pc@us.ibm.com> + + * sysdeps/powerpc/fpu/fenv_libc.h: Define FPSCR bitmasks. + (fenv_reg_to_exceptions): Replace bitwise operations with mask-shift. + (fenv_exceptions_to_reg): New. + * sysdeps/powerpc/fpu/fedisblxcpt.c (fedisableexcept): Replace bitwise + operation with call to fenv_exceptions_to_reg(). + * sysdeps/powerpc/fpu/feenablxcpt.c (feenableexcept): Likewise. + 2019-08-28 Florian Weimer <fweimer@redhat.com> * misc/mntent.c (struct mntent_buffer): Define. |