diff options
Diffstat (limited to 'libthreads/lockfile.c')
-rw-r--r-- | libthreads/lockfile.c | 51 |
1 files changed, 5 insertions, 46 deletions
diff --git a/libthreads/lockfile.c b/libthreads/lockfile.c index c815185c..2fe9800b 100644 --- a/libthreads/lockfile.c +++ b/libthreads/lockfile.c @@ -1,5 +1,5 @@ -/* lockfile - Handle locking and unlocking of stream. Hurd cthreads version. - Copyright (C) 2000 Free Software Foundation, Inc. +/* lockfile - Handle locking and unlocking of streams. Hurd cthreads version. + Copyright (C) 2000,01 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 @@ -18,68 +18,27 @@ Boston, MA 02111-1307, USA. */ #include <cthreads.h> /* Must come before <stdio.h>! */ - -#define _IO_MTSAFE_IO #include <stdio.h> -#include <assert.h> - #ifdef _STDIO_USES_IOSTREAM void _cthreads_flockfile (_IO_FILE *fp) { - cthread_t self = cthread_self (); - - if (fp->_lock->owner == self) - { - assert (fp->_lock->count != 0); - ++fp->_lock->count; - } - else - { - mutex_lock (&fp->_lock->mutex); - assert (fp->_lock->owner == 0); - fp->_lock->owner = self; - assert (fp->_lock->count == 0); - fp->_lock->count = 1; - } + _IO_lock_lock (*fp->_lock); } void _cthreads_funlockfile (_IO_FILE *fp) { - if (--fp->_lock->count == 0) - { - assert (fp->_lock->owner == cthread_self ()); - fp->_lock->owner = 0; - mutex_unlock (&fp->_lock->mutex); - } + _IO_lock_unlock (*fp->_lock); } int _cthreads_ftrylockfile (_IO_FILE *fp) { - cthread_t self = cthread_self (); - - if (fp->_lock->owner == self) - { - assert (fp->_lock->count != 0); - ++fp->_lock->count; - } - else if (mutex_try_lock (&fp->_lock->mutex)) - { - assert (fp->_lock->owner == 0); - fp->_lock->owner = self; - assert (fp->_lock->count == 0); - fp->_lock->count = 1; - } - else - return 0; /* No lock for us. */ - - /* We got the lock. */ - return 1; + return __libc_lock_trylock_recursive (*fp->_lock); } |