]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
nptl: PTHREAD_COND_INITIALIZER compatibility with pre-2.41 versions (bug 32786)
authorFlorian Weimer <fweimer@redhat.com>
Thu, 13 Mar 2025 05:07:07 +0000 (06:07 +0100)
committerFlorian Weimer <fweimer@redhat.com>
Thu, 13 Mar 2025 06:43:33 +0000 (07:43 +0100)
The new initializer and struct layout does not initialize the
__g_signals field in the old struct layout before the change in
commit c36fc50781995e6758cae2b6927839d0157f213c ("nptl: Remove
g_refs from condition variables").  Bring back fields at the end
of struct __pthread_cond_s, so that they are again zero-initialized.

Reviewed-by: Sam James <sam@gentoo.org>
sysdeps/nptl/bits/thread-shared-types.h
sysdeps/nptl/pthread.h

index 7c24c0a6be3fbe17677a0f67b6c6436123652c37..e614c7f3c900eba098d978ed4ce972146ad85338 100644 (file)
@@ -99,6 +99,8 @@ struct __pthread_cond_s
   unsigned int __g1_orig_size;
   unsigned int __wrefs;
   unsigned int __g_signals[2];
+  unsigned int __unused_initialized_1;
+  unsigned int __unused_initialized_2;
 };
 
 typedef unsigned int __tss_t;
index b4d10a37c6d0eb456f2a17acbb05865f2da3a29b..92957a620d9584685dbbd2fb3bf5dc8f050d1041 100644 (file)
@@ -152,7 +152,7 @@ enum
 
 
 /* Conditional variable handling.  */
-#define PTHREAD_COND_INITIALIZER { { {0}, {0}, {0, 0}, 0, 0, {0, 0} } }
+#define PTHREAD_COND_INITIALIZER { { {0}, {0}, {0, 0}, 0, 0, {0, 0}, 0, 0 } }
 
 
 /* Cleanup buffers */