summaryrefslogtreecommitdiff
path: root/libpthread/sysdeps
diff options
context:
space:
mode:
authorneal <neal>2008-01-01 17:42:41 +0000
committerneal <neal>2008-01-01 17:42:41 +0000
commit4b3f8b0904d1b3e8b7b6837e31e940f8180bd5bf (patch)
treedbeacac5f7eef49e64cc90a4151b975b28fcaeea /libpthread/sysdeps
parentabd5f5b37175397568c948002385f734d5f1ecbc (diff)
2008-01-01 Neal H. Walfield <neal@gnu.org>
* sysdeps/generic/pt-mutex-timedlock.c (__pthread_mutex_timedlock_internal): Add additional asserts. [! NDEBUG]: Keep MUTEX->OWNER up to date. * sysdeps/generic/pt-mutex-trylock.c (__pthread_mutex_trylock): Add additional asserts. [! NDEBUG]: Keep MUTEX->OWNER up to date. * sysdeps/generic/pt-mutex-unlock.c (__pthread_mutex_unlock): Add additional asserts. [! NDEBUG]: Keep MUTEX->OWNER up to date.
Diffstat (limited to 'libpthread/sysdeps')
-rw-r--r--libpthread/sysdeps/generic/pt-mutex-timedlock.c31
-rw-r--r--libpthread/sysdeps/generic/pt-mutex-trylock.c14
-rw-r--r--libpthread/sysdeps/generic/pt-mutex-unlock.c19
3 files changed, 53 insertions, 11 deletions
diff --git a/libpthread/sysdeps/generic/pt-mutex-timedlock.c b/libpthread/sysdeps/generic/pt-mutex-timedlock.c
index 5e222bd..6db30c5 100644
--- a/libpthread/sysdeps/generic/pt-mutex-timedlock.c
+++ b/libpthread/sysdeps/generic/pt-mutex-timedlock.c
@@ -1,5 +1,5 @@
/* Lock a mutex with a timeout. Generic version.
- Copyright (C) 2000, 2002, 2005 Free Software Foundation, Inc.
+ Copyright (C) 2000, 2002, 2005, 2008 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
@@ -36,6 +36,18 @@ __pthread_mutex_timedlock_internal (struct __pthread_mutex *mutex,
if (__pthread_spin_trylock (&mutex->__held) == 0)
/* Successfully acquired the lock. */
{
+#ifndef NDEBUG
+ self = _pthread_self ();
+ if (self)
+ /* The main thread may take a lock before the library is fully
+ initialized, in particular, before the main thread has a
+ TCB. */
+ {
+ assert (! mutex->owner);
+ mutex->owner = _pthread_self ();
+ }
+#endif
+
if (mutex->attr)
switch (mutex->attr->mutex_type)
{
@@ -59,12 +71,14 @@ __pthread_mutex_timedlock_internal (struct __pthread_mutex *mutex,
/* The lock is busy. */
self = _pthread_self ();
+ assert (self);
if (mutex->attr)
{
switch (mutex->attr->mutex_type)
{
case PTHREAD_MUTEX_NORMAL:
+ assert (mutex->owner != self);
break;
case PTHREAD_MUTEX_ERRORCHECK:
@@ -88,6 +102,10 @@ __pthread_mutex_timedlock_internal (struct __pthread_mutex *mutex,
LOSE;
}
}
+ else
+ assert (mutex->owner != self);
+
+ assert (mutex->owner);
if (abstime && (abstime->tv_nsec < 0 || abstime->tv_nsec >= 1000000000))
return EINVAL;
@@ -123,12 +141,15 @@ __pthread_mutex_timedlock_internal (struct __pthread_mutex *mutex,
else
__pthread_block (self);
- if (mutex->attr)
+ if (! mutex->attr || mutex->attr->mutex_type == PTHREAD_MUTEX_NORMAL)
+ {
+#ifndef NDEBUG
+ mutex->owner = self;
+#endif
+ }
+ else
switch (mutex->attr->mutex_type)
{
- case PTHREAD_MUTEX_NORMAL:
- break;
-
case PTHREAD_MUTEX_RECURSIVE:
assert (mutex->locks == 0);
mutex->locks = 1;
diff --git a/libpthread/sysdeps/generic/pt-mutex-trylock.c b/libpthread/sysdeps/generic/pt-mutex-trylock.c
index d56f6e1..5264dc7 100644
--- a/libpthread/sysdeps/generic/pt-mutex-trylock.c
+++ b/libpthread/sysdeps/generic/pt-mutex-trylock.c
@@ -1,5 +1,5 @@
/* Try to Lock a mutex. Generic version.
- Copyright (C) 2002, 2005 Free Software Foundation, Inc.
+ Copyright (C) 2002, 2005, 2008 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
@@ -34,6 +34,18 @@ __pthread_mutex_trylock (struct __pthread_mutex *mutex)
if (__pthread_spin_trylock (&mutex->__held) == 0)
/* Acquired the lock. */
{
+#ifndef NDEBUG
+ self = _pthread_self ();
+ if (self)
+ /* The main thread may take a lock before the library is fully
+ initialized, in particular, before the main thread has a
+ TCB. */
+ {
+ assert (! mutex->owner);
+ mutex->owner = _pthread_self ();
+ }
+#endif
+
if (mutex->attr)
switch (mutex->attr->mutex_type)
{
diff --git a/libpthread/sysdeps/generic/pt-mutex-unlock.c b/libpthread/sysdeps/generic/pt-mutex-unlock.c
index 2f719d3..a987225 100644
--- a/libpthread/sysdeps/generic/pt-mutex-unlock.c
+++ b/libpthread/sysdeps/generic/pt-mutex-unlock.c
@@ -1,5 +1,5 @@
/* Unlock a mutex. Generic version.
- Copyright (C) 2000,02 Free Software Foundation, Inc.
+ Copyright (C) 2000, 2002, 2008 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
@@ -31,12 +31,20 @@ __pthread_mutex_unlock (pthread_mutex_t *mutex)
__pthread_spin_lock (&mutex->__lock);
- if (mutex->attr)
+ if (! mutex->attr || mutex->attr->mutex_type == PTHREAD_MUTEX_NORMAL)
+ {
+#ifndef NDEBUG
+ if (_pthread_self ())
+ {
+ assert (mutex->owner);
+ assert (mutex->owner == _pthread_self ());
+ mutex->owner = NULL;
+ }
+#endif
+ }
+ else
switch (mutex->attr->mutex_type)
{
- case PTHREAD_MUTEX_NORMAL:
- break;
-
case PTHREAD_MUTEX_ERRORCHECK:
case PTHREAD_MUTEX_RECURSIVE:
if (mutex->owner != _pthread_self ())
@@ -59,6 +67,7 @@ __pthread_mutex_unlock (pthread_mutex_t *mutex)
LOSE;
}
+
if (mutex->__queue == NULL)
{
__pthread_spin_unlock (&mutex->__held);