diff options
author | Ulrich Drepper <drepper@redhat.com> | 1998-10-29 14:31:12 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 1998-10-29 14:31:12 +0000 |
commit | 05e951cd1ae7917ce25ec96cc17ebcbf401e345c (patch) | |
tree | 00ddb0a1560c30825ef7ce1897c823d3d64ccd2a /linuxthreads/spinlock.h | |
parent | cf3a0eca819aff2c4f44989ee66d7f0099b2d92e (diff) | |
download | glibc-05e951cd1ae7917ce25ec96cc17ebcbf401e345c.tar.gz glibc-05e951cd1ae7917ce25ec96cc17ebcbf401e345c.tar.xz glibc-05e951cd1ae7917ce25ec96cc17ebcbf401e345c.zip |
(__pthread_trylock): Define inline. (__pthread_lock): Add extra parameter to declaration. Declare using internal_function. (__pthread_unlock): Declare using internal_function.
Diffstat (limited to 'linuxthreads/spinlock.h')
-rw-r--r-- | linuxthreads/spinlock.h | 41 |
1 files changed, 26 insertions, 15 deletions
diff --git a/linuxthreads/spinlock.h b/linuxthreads/spinlock.h index a6f682cb69..29f030406c 100644 --- a/linuxthreads/spinlock.h +++ b/linuxthreads/spinlock.h @@ -12,20 +12,6 @@ /* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the */ /* GNU Library General Public License for more details. */ -/* Internal locks */ - -extern void __pthread_lock(struct _pthread_fastlock * lock); -extern int __pthread_trylock(struct _pthread_fastlock * lock); -extern void __pthread_unlock(struct _pthread_fastlock * lock); - -static inline void __pthread_init_lock(struct _pthread_fastlock * lock) -{ - lock->__status = 0; - lock->__spinlock = 0; -} - -#define LOCK_INITIALIZER {0, 0} - #if defined(TEST_FOR_COMPARE_AND_SWAP) extern int __pthread_has_cas; @@ -35,7 +21,7 @@ extern int __pthread_compare_and_swap(long * ptr, long oldval, long newval, static inline int compare_and_swap(long * ptr, long oldval, long newval, int * spinlock) { - if (__pthread_has_cas) + if (__builtin_expect (__pthread_has_cas, 1)) return __compare_and_swap(ptr, oldval, newval); else return __pthread_compare_and_swap(ptr, oldval, newval, spinlock); @@ -61,3 +47,28 @@ static inline int compare_and_swap(long * ptr, long oldval, long newval, } #endif + +/* Internal locks */ + +extern void internal_function __pthread_lock(struct _pthread_fastlock * lock, + pthread_descr self); +extern void internal_function __pthread_unlock(struct _pthread_fastlock *lock); + +static inline void __pthread_init_lock(struct _pthread_fastlock * lock) +{ + lock->__status = 0; + lock->__spinlock = 0; +} + +static inline int __pthread_trylock (struct _pthread_fastlock * lock) +{ + long oldstatus; + + do { + oldstatus = lock->__status; + if (oldstatus != 0) return EBUSY; + } while(! compare_and_swap(&lock->__status, 0, 1, &lock->__spinlock)); + return 0; +} + +#define LOCK_INITIALIZER {0, 0} |