123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 |
- #include <errno.h>
- #include <pthread.h>
- #include "internals.h"
- int
- __pthread_spin_lock (pthread_spinlock_t *lock)
- {
- unsigned int tmp;
- __asm__ __volatile__
- ("1: ldl_l %0,%1\n"
- " blbs %0,2f\n"
- " or %0,1,%0\n"
- " stl_c %0,%1\n"
- " beq %0,2f\n"
- " mb\n"
- ".subsection 2\n"
- "2: ldl %0,%1\n"
- " blbs %0,2b\n"
- " br 1b\n"
- ".previous"
- : "=r" (tmp), "=m" (lock)
- : "m" (lock));
- return 0;
- }
- weak_alias (__pthread_spin_lock, pthread_spin_lock)
- int
- __pthread_spin_trylock (pthread_spinlock_t *lock)
- {
- unsigned long int oldval;
- unsigned long int temp;
- __asm__ __volatile__
- ("1: ldl_l %0,%1\n"
- " and %0,%3,%2\n"
- " bne %2,2f\n"
- " xor %0,%3,%0\n"
- " stl_c %0,%1\n"
- " beq %0,3f\n"
- " mb\n"
- "2:\n"
- ".subsection 2\n"
- "3: br 1b\n"
- ".previous"
- : "=&r" (temp), "=m" (*lock), "=&r" (oldval)
- : "Ir" (1UL), "m" (*lock));
- return oldval == 0 ? 0 : EBUSY;
- }
- weak_alias (__pthread_spin_trylock, pthread_spin_trylock)
- int
- __pthread_spin_unlock (pthread_spinlock_t *lock)
- {
- __asm__ __volatile__ ("mb");
- return *lock = 0;
- }
- weak_alias (__pthread_spin_unlock, pthread_spin_unlock)
- int
- __pthread_spin_init (pthread_spinlock_t *lock, int pshared)
- {
-
- *lock = 0;
- return 0;
- }
- weak_alias (__pthread_spin_init, pthread_spin_init)
- int
- __pthread_spin_destroy (pthread_spinlock_t *lock)
- {
-
- return 0;
- }
- weak_alias (__pthread_spin_destroy, pthread_spin_destroy)
|