Filter out PTHREAD_MUTEX_NO_ELISION_NP bit in pthread_mutexattr_gettype (BZ #15790)
authorAndreas Schwab <schwab@suse.de>
Mon, 11 Aug 2014 09:18:26 +0000 (11:18 +0200)
committerAndreas Schwab <schwab@suse.de>
Thu, 12 Feb 2015 08:26:00 +0000 (09:26 +0100)
pthread_mutexattr_settype adds PTHREAD_MUTEX_NO_ELISION_NP to kind,
which is an internal flag that pthread_mutexattr_gettype shouldn't
expose, since pthread_mutexattr_settype wouldn't accept it.

ChangeLog
NEWS
nptl/Makefile
nptl/pthread_mutexattr_gettype.c
nptl/tst-pthread-mutexattr.c [new file with mode: 0644]

index bf4ddd0..2941ec1 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,11 @@
+2015-02-12  Andreas Schwab  <schwab@suse.de>
+
+       [BZ #15790]
+       * nptl/pthread_mutexattr_gettype.c (pthread_mutexattr_gettype):
+       Filter out elision flags from value returned in kind.
+       * nptl/Makefile (tests): Add tst-pthread-mutexattr.
+       * nptl/tst-pthread-mutexattr.c: New file.
+
 2015-02-11  Samuel Thibault  <samuel.thibault@ens-lyon.org>
 
        * abi-tags: Revert ae20c9a: rename back gnu into gnu-gnu.
diff --git a/NEWS b/NEWS
index 2d4ebb9..2938f6e 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -9,7 +9,7 @@ Version 2.22
 
 * The following bugs are resolved with this release:
 
-  4719, 15467, 17912, 17932, 17944, 17949.
+  4719, 15467, 15790, 17912, 17932, 17944, 17949.
 \f
 Version 2.21
 
index 6ae76bb..89fdc8b 100644 (file)
@@ -256,7 +256,7 @@ tests = tst-typesizes \
        tst-exit1 tst-exit2 tst-exit3 \
        tst-stdio1 tst-stdio2 \
        tst-stack1 tst-stack2 tst-stack3 tst-stack4 tst-pthread-getattr \
-       tst-pthread-attr-affinity \
+       tst-pthread-attr-affinity tst-pthread-mutexattr \
        tst-unload \
        tst-dlsym1 \
        tst-sysconf \
index 72419bd..0bf2c82 100644 (file)
@@ -28,7 +28,8 @@ pthread_mutexattr_gettype (attr, kind)
 
   iattr = (const struct pthread_mutexattr *) attr;
 
-  *kind = iattr->mutexkind & ~PTHREAD_MUTEXATTR_FLAG_BITS;
+  *kind = (iattr->mutexkind & ~PTHREAD_MUTEXATTR_FLAG_BITS
+          & ~PTHREAD_MUTEX_NO_ELISION_NP);
 
   return 0;
 }
diff --git a/nptl/tst-pthread-mutexattr.c b/nptl/tst-pthread-mutexattr.c
new file mode 100644 (file)
index 0000000..10ebe50
--- /dev/null
@@ -0,0 +1,60 @@
+/* Make sure that pthread_mutexattr_gettype returns a valid kind.
+
+   Copyright (C) 2015 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
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include <stdio.h>
+#include <string.h>
+#include <pthread.h>
+
+static int
+do_test (void)
+{
+  pthread_mutexattr_t attr;
+  int kind;
+  int error;
+
+  error = pthread_mutexattr_init (&attr);
+  if (error)
+    {
+      printf ("pthread_mutexattr_init: %s\n", strerror (error));
+      return 1;
+    }
+  error = pthread_mutexattr_settype (&attr, PTHREAD_MUTEX_DEFAULT);
+  if (error)
+    {
+      printf ("pthread_mutexattr_settype (1): %s\n", strerror (error));
+      return 1;
+    }
+  error = pthread_mutexattr_gettype (&attr, &kind);
+  if (error)
+    {
+      printf ("pthread_mutexattr_gettype: %s\n", strerror (error));
+      return 1;
+    }
+  error = pthread_mutexattr_settype (&attr, kind);
+  if (error)
+    {
+      printf ("pthread_mutexattr_settype (2): %s\n", strerror (error));
+      return 1;
+    }
+  return 0;
+}
+
+
+#define TEST_FUNCTION do_test ()
+#include "../test-skeleton.c"