Don't test pthread objects for being already initialized at init time
For all pthread init functions, POSIX says Results are undefined if pthread_FOO_init() is called specifying an already initialized pthread_FOO object. So far our pthread init functions tested the incoming object if it's already an initialized object and, if so, returned EBUSY. That's ok *iff* the object was already initialized. However, as the example in https://cygwin.com/ml/cygwin/2016-04/msg00473.html shows, an uninitialized pthread object could also accidentally look like an initialized object and then returning EBUSY is not ok. Consequentially, all those tests are dangerous. Per POSIX, an application has to know what its doing when calling any of the pthread init functions anyway, and re-initializing the object is just as well as undefined behaviour as is returning EBUSY on already initialized objects. * thread.cc (pthread_attr_init): Drop check for already initialized object. (pthread_condattr_init): Ditto. (pthread_rwlockattr_init): Ditto. (pthread_mutexattr_init): Ditto. Signed-off-by: Corinna Vinschen <corinna@vinschen.de>
This commit is contained in:
parent
6ee81f44e0
commit
9409c5335b
@ -2175,9 +2175,6 @@ pthread::atfork (void (*prepare)(void), void (*parent)(void), void (*child)(void
|
|||||||
extern "C" int
|
extern "C" int
|
||||||
pthread_attr_init (pthread_attr_t *attr)
|
pthread_attr_init (pthread_attr_t *attr)
|
||||||
{
|
{
|
||||||
if (pthread_attr::is_good_object (attr))
|
|
||||||
return EBUSY;
|
|
||||||
|
|
||||||
*attr = new pthread_attr;
|
*attr = new pthread_attr;
|
||||||
if (!pthread_attr::is_good_object (attr))
|
if (!pthread_attr::is_good_object (attr))
|
||||||
{
|
{
|
||||||
@ -2854,9 +2851,6 @@ pthread_cond_wait (pthread_cond_t *cond, pthread_mutex_t *mutex)
|
|||||||
extern "C" int
|
extern "C" int
|
||||||
pthread_condattr_init (pthread_condattr_t *condattr)
|
pthread_condattr_init (pthread_condattr_t *condattr)
|
||||||
{
|
{
|
||||||
if (pthread_condattr::is_good_object (condattr))
|
|
||||||
return EBUSY;
|
|
||||||
|
|
||||||
*condattr = new pthread_condattr;
|
*condattr = new pthread_condattr;
|
||||||
if (!pthread_condattr::is_good_object (condattr))
|
if (!pthread_condattr::is_good_object (condattr))
|
||||||
{
|
{
|
||||||
@ -3040,9 +3034,6 @@ pthread_rwlock_unlock (pthread_rwlock_t *rwlock)
|
|||||||
extern "C" int
|
extern "C" int
|
||||||
pthread_rwlockattr_init (pthread_rwlockattr_t *rwlockattr)
|
pthread_rwlockattr_init (pthread_rwlockattr_t *rwlockattr)
|
||||||
{
|
{
|
||||||
if (pthread_rwlockattr::is_good_object (rwlockattr))
|
|
||||||
return EBUSY;
|
|
||||||
|
|
||||||
*rwlockattr = new pthread_rwlockattr;
|
*rwlockattr = new pthread_rwlockattr;
|
||||||
if (!pthread_rwlockattr::is_good_object (rwlockattr))
|
if (!pthread_rwlockattr::is_good_object (rwlockattr))
|
||||||
{
|
{
|
||||||
@ -3370,9 +3361,6 @@ pthread_mutexattr_gettype (const pthread_mutexattr_t *attr, int *type)
|
|||||||
extern "C" int
|
extern "C" int
|
||||||
pthread_mutexattr_init (pthread_mutexattr_t *attr)
|
pthread_mutexattr_init (pthread_mutexattr_t *attr)
|
||||||
{
|
{
|
||||||
if (pthread_mutexattr::is_good_object (attr))
|
|
||||||
return EBUSY;
|
|
||||||
|
|
||||||
*attr = new pthread_mutexattr ();
|
*attr = new pthread_mutexattr ();
|
||||||
if (!pthread_mutexattr::is_good_object (attr))
|
if (!pthread_mutexattr::is_good_object (attr))
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user