cross-thread locking
Daniel Eischen
eischen at vigrid.com
Fri Feb 20 11:45:46 PST 2004
On Fri, 20 Feb 2004, Dag-Erling [iso-8859-1] Sm=F8rgrav wrote:
> Daniel Eischen <eischen at vigrid.com> writes:
> > POSIX differentiates between spinlocks and mutexes, and that is
> > why there is a pthread_spinlock_t instead of using pthread_mutex_t
> > for both lock operations. I believe the implementation is allowed
> > to spin indefinitely or schedule another thread if the lock is
> > busy.
>=20
> In other words, the semantics for the two are identical?
Yes, you use them in the same way.
> BTW, I looked at the libpthread sources, and it seems to me that a
> spinlock is just a wrapper around a mutex, though the comments
> contradict this.
I think you are looking at spinlocks, not pthread_spinlocks.
Look at thr_pspinlock.c, not thr_spinlock.c. The latter is
used for internal spinlock usage by libc. Libc spinlocks
are unfortunately named and should just be libc_locks or
something.
> Going off on a tangent, is there a value one can assign to a pthread_t
> to make it unambiguously invalid? Obviously, NULL or 0 will work in
> FreeBSD since our pthread_t is a pointer to a struct pthread, but I'm
> looking for something more portable.
Not that I know of.
--=20
Dan Eischen
More information about the freebsd-threads
mailing list