olga / rpms / glibc

Forked from rpms/glibc 5 years ago
Clone
00db10
commit 693096cc7b397a709f075865993027c14c06d3e5
00db10
Author: Wilco <wdijkstr@arm.com>
00db10
Date:   Tue Jun 3 08:10:39 2014 +0000
00db10
00db10
    [AArch64] Switch from FE_TOWARDZERO to _FPU_FPCR_RM_MASK
00db10
00db10
diff --git a/ports/sysdeps/aarch64/fpu/get-rounding-mode.h b/ports/sysdeps/aarch64/fpu/get-rounding-mode.h
00db10
index 5c1615d..425b50e 100644
00db10
--- a/ports/sysdeps/aarch64/fpu/get-rounding-mode.h
00db10
+++ b/ports/sysdeps/aarch64/fpu/get-rounding-mode.h
00db10
@@ -32,7 +32,7 @@ get_rounding_mode (void)
00db10
   fpu_control_t fpcr;
00db10
 
00db10
   _FPU_GETCW (fpcr);
00db10
-  return fpcr & FE_TOWARDZERO;
00db10
+  return fpcr & _FPU_FPCR_RM_MASK;
00db10
 }
00db10
 
00db10
 #endif /* get-rounding-mode.h */
00db10
diff --git a/ports/sysdeps/aarch64/fpu/math_private.h b/ports/sysdeps/aarch64/fpu/math_private.h
00db10
index a3f466b..023c9d0 100644
00db10
--- a/ports/sysdeps/aarch64/fpu/math_private.h
00db10
+++ b/ports/sysdeps/aarch64/fpu/math_private.h
00db10
@@ -58,7 +58,7 @@ libc_fesetround_aarch64 (int round)
00db10
   _FPU_GETCW (fpcr);
00db10
 
00db10
   /* Check whether rounding modes are different.  */
00db10
-  round = (fpcr ^ round) & FE_TOWARDZERO;
00db10
+  round = (fpcr ^ round) & _FPU_FPCR_RM_MASK;
00db10
 
00db10
   /* Set new rounding mode if different.  */
00db10
   if (__glibc_unlikely (round != 0))
00db10
@@ -84,7 +84,7 @@ libc_feholdexcept_setround_aarch64 (fenv_t *envp, int round)
00db10
 
00db10
   /* Clear exception flags, set all exceptions to non-stop,
00db10
      and set new rounding mode.  */
00db10
-  new_fpcr = fpcr & ~((FE_ALL_EXCEPT << FE_EXCEPT_SHIFT) | FE_TOWARDZERO);
00db10
+  new_fpcr = fpcr & ~((FE_ALL_EXCEPT << FE_EXCEPT_SHIFT) | _FPU_FPCR_RM_MASK);
00db10
   new_fpcr |= round;
00db10
   new_fpsr = fpsr & ~FE_ALL_EXCEPT;
00db10
 
00db10
@@ -190,7 +190,7 @@ libc_feholdsetround_aarch64 (fenv_t *envp, int round)
00db10
   envp->__fpsr = fpsr;
00db10
 
00db10
   /* Check whether rounding modes are different.  */
00db10
-  round = (fpcr ^ round) & FE_TOWARDZERO;
00db10
+  round = (fpcr ^ round) & _FPU_FPCR_RM_MASK;
00db10
 
00db10
   /* Set new rounding mode if different.  */
00db10
   if (__glibc_unlikely (round != 0))
00db10
@@ -210,7 +210,7 @@ libc_feresetround_aarch64 (fenv_t *envp)
00db10
   _FPU_GETCW (fpcr);
00db10
 
00db10
   /* Check whether rounding modes are different.  */
00db10
-  round = (envp->__fpcr ^ fpcr) & FE_TOWARDZERO;
00db10
+  round = (envp->__fpcr ^ fpcr) & _FPU_FPCR_RM_MASK;
00db10
 
00db10
   /* Restore the rounding mode if it was changed.  */
00db10
   if (__glibc_unlikely (round != 0))
00db10
@@ -236,7 +236,7 @@ libc_feholdsetround_aarch64_ctx (struct rm_ctx *ctx, int r)
00db10
   ctx->env.__fpsr = fpsr;
00db10
 
00db10
   /* Check whether rounding modes are different.  */
00db10
-  round = (fpcr ^ r) & FE_TOWARDZERO;
00db10
+  round = (fpcr ^ r) & _FPU_FPCR_RM_MASK;
00db10
   ctx->updated_status = round != 0;
00db10
 
00db10
   /* Set the rounding mode if changed.  */