]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Fix FPU context handling in getcontext on x86-64.
authorUlrich Drepper <drepper@gmail.com>
Mon, 18 Apr 2011 01:51:26 +0000 (21:51 -0400)
committerUlrich Drepper <drepper@gmail.com>
Mon, 18 Apr 2011 01:51:26 +0000 (21:51 -0400)
fnstenv on x86-64 seems to clear the state.  Work around.

ChangeLog
NEWS
stdlib/Makefile
stdlib/bug-getcontext.c [new file with mode: 0644]
sysdeps/unix/sysv/linux/x86_64/getcontext.S

index b2d2597b25b6430c60fe0f79d2de93d07f853f28..d53eff355fa058476307b65045a07a710ab2fb7b 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,11 @@
+2011-04-17  Ulrich Drepper  <drepper@gmail.com>
+
+       [BZ #12420]
+       * sysdeps/unix/sysv/linux/x86_64/getcontext.S: Reload context after
+       storing it.
+       * stdlib/bug-getcontext.c: New file.
+       * stdlib/Makefile: Add rules to build and run bug-getcontext.
+
 2011-04-13  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
 
        * sysdeps/s390/s390-64/utf16-utf32-z9.c: Wrap the z9-109
diff --git a/NEWS b/NEWS
index 670dbf3018228e80708d9d868416073305dda8f7..e5e4b773c116460f695cda2dc351b90409554446 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -1,4 +1,4 @@
-GNU C Library NEWS -- history of user-visible changes.  2011-4-16
+GNU C Library NEWS -- history of user-visible changes.  2011-4-17
 Copyright (C) 1992-2009, 2010, 2011 Free Software Foundation, Inc.
 See the end for copying conditions.
 
@@ -18,8 +18,8 @@ Version 2.14
 
 * The following bugs are resolved with this release:
 
-  11724, 12445, 12454, 12460, 12469, 12489, 12509, 12510, 12518, 12583, 12587,
-  12597, 12631, 12650, 12655
+  11724, 12420, 12445, 12454, 12460, 12469, 12489, 12509, 12510, 12518, 12583,
+  12587, 12597, 12631, 12650, 12655
 \f
 Version 2.13
 
index bb0661af3bb91f67197ee0a30527179ea6af18f8..04c6ac5cae0f4fcf1cb37f4c921a2e71cc51897e 100644 (file)
@@ -1,4 +1,4 @@
-# Copyright (C) 1991-2006, 2007, 2008, 2009 Free Software Foundation, Inc.
+# Copyright (C) 1991-2009, 2011 Free Software Foundation, Inc.
 # This file is part of the GNU C Library.
 
 # The GNU C Library is free software; you can redistribute it and/or
@@ -71,7 +71,7 @@ tests         := tst-strtol tst-strtod testmb testrand testsort testdiv   \
                   tst-atof1 tst-atof2 tst-strtod2 tst-strtod3 tst-rand48-2 \
                   tst-makecontext tst-strtod4 tst-strtod5 tst-qsort2       \
                   tst-makecontext2 tst-strtod6 tst-unsetenv1               \
-                  tst-makecontext3
+                  tst-makecontext3 bug-getcontext
 
 include ../Makeconfig
 
@@ -145,3 +145,10 @@ $(objpfx)tst-putenv: $(objpfx)tst-putenvmod.so
 $(objpfx)tst-putenvmod.so: $(objpfx)tst-putenvmod.os
        $(build-module)
 CFLAGS-tst-putenvmod.c = -DNOT_IN_libc=1
+
+ifeq ($(build-shared),yes)
+link-libm = $(common-objpfx)math/libm.so
+else
+link-libm = $(common-objpfx)math/libm.a
+endif
+$(objpfx)bug-getcontext: $(link-libm)
diff --git a/stdlib/bug-getcontext.c b/stdlib/bug-getcontext.c
new file mode 100644 (file)
index 0000000..745aa1f
--- /dev/null
@@ -0,0 +1,48 @@
+/* BZ 12420 */
+
+#include <errno.h>
+#include <fenv.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <ucontext.h>
+
+static int
+do_test (void)
+{
+  int except_mask =  FE_DIVBYZERO | FE_INVALID | FE_OVERFLOW | FE_UNDERFLOW;
+  int status = feenableexcept (except_mask);
+
+  except_mask = fegetexcept ();
+  if (except_mask == -1)
+    {
+      printf("\nBefore getcontext(): fegetexcept returned: %d\n",
+            except_mask);
+      return 1;
+    }
+
+  ucontext_t ctx;
+  status = getcontext(&ctx);
+  if (status)
+    {
+      printf("\ngetcontext failed, errno: %d.\n", errno);
+      return 1;
+    }
+
+  printf ("\nDone with getcontext()!\n");
+  fflush (NULL);
+
+  int mask = fegetexcept ();
+  if (mask != except_mask)
+    {
+      printf("\nAfter getcontext(): fegetexcept returned: %d, expected: %d.\n",
+            mask, except_mask);
+      return 1;
+    }
+
+  printf("\nAt end fegetexcept() returned %d, expected: %d.\n",
+        mask, except_mask);
+  return 0;
+}
+
+#define TEST_FUNCTION do_test ()
+#include "../test-skeleton.c"
index 4bbc7a4d2e9f7497e754edd82e05061e212d908e..1a31d72dad7cf9ed1ebaa92526ad23fc885fbafa 100644 (file)
@@ -1,5 +1,5 @@
 /* Save current context.
-   Copyright (C) 2002, 2005 Free Software Foundation, Inc.
+   Copyright (C) 2002, 2005, 2011 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Andreas Jaeger <aj@suse.de>, 2002.
 
@@ -62,6 +62,7 @@ ENTRY(__getcontext)
        movq    %rcx, oFPREGS(%rdi)
        /* Save the floating-point environment.  */
        fnstenv (%rcx)
+       fldenv  (%rcx)
        stmxcsr oMXCSR(%rdi)
 
        /* Save the current signal mask with