about summary refs log tree commit diff
path: root/ports/sysdeps
diff options
context:
space:
mode:
authorJoseph Myers <joseph@codesourcery.com>2013-06-17 17:20:23 +0000
committerJoseph Myers <joseph@codesourcery.com>2013-06-17 17:20:23 +0000
commit3023a72eb83751a23b01b6cb996fb81fe3abbcb6 (patch)
tree9dc05fe06ed6a8dd31c1809666bc0f568ea5fdab /ports/sysdeps
parent12086fb4835639d1762622d80980a7500799b63e (diff)
downloadglibc-3023a72eb83751a23b01b6cb996fb81fe3abbcb6.tar.gz
glibc-3023a72eb83751a23b01b6cb996fb81fe3abbcb6.tar.xz
glibc-3023a72eb83751a23b01b6cb996fb81fe3abbcb6.zip
Make ARM feenableexcept detect failure (bug 14907).
Diffstat (limited to 'ports/sysdeps')
-rw-r--r--ports/sysdeps/arm/feenablxcpt.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/ports/sysdeps/arm/feenablxcpt.c b/ports/sysdeps/arm/feenablxcpt.c
index baad4320cc..e2e287b6e5 100644
--- a/ports/sysdeps/arm/feenablxcpt.c
+++ b/ports/sysdeps/arm/feenablxcpt.c
@@ -39,6 +39,18 @@ feenableexcept (int excepts)
 
       _FPU_SETCW(new_exc);
 
+      if (excepts != 0)
+	{
+	  /* VFPv3 and VFPv4 do not support trapping exceptions, so
+	     test whether the relevant bits were set and fail if
+	     not.  */
+	  unsigned int temp;
+	  _FPU_GETCW (temp);
+	  if ((temp & (excepts << FE_EXCEPT_SHIFT))
+	      != (excepts << FE_EXCEPT_SHIFT))
+	    return -1;
+	}
+
       return old_exc;
     }