svn commit: r215071 - in user/davidxu/libthr: include lib/libc
lib/libc/gen lib/libc/stdio lib/libthr lib/libthr/thread
John Baldwin
jhb at freebsd.org
Fri Nov 12 16:03:23 UTC 2010
On Friday, November 12, 2010 8:19:42 am Jilles Tjoelker wrote:
> On Wed, Nov 10, 2010 at 01:27:48AM +0000, David Xu wrote:
> > Author: davidxu
> > Date: Wed Nov 10 01:27:48 2010
> > New Revision: 215071
> > URL: http://svn.freebsd.org/changeset/base/215071
>
> > Log:
> > Convert pthread_mutex_t and pthread_cond_t to structure based instead of
> > pointer type, this allows us to support process-shared.
>
> Very nice.
>
> Apart from supporting process-shared, this also helps avoid the "array
> of synchronization objects" anti-pattern (false sharing). It is not so
> bad for the old struct pthread_mutex which is 64 bytes on i386, but in
> other cases one cache line may contain parts of multiple unrelated
> synchronization objects.
>
> In this regard, it would be better for stdio to allocate
> struct { FILE file; pthread_mutex_t lock; }
> rather than separate FILEs and locks.
Note that stdio already does this. It currently expands 'pthread_mutex_t'
to avoid namespace pollution in <stdio.h>, but it does embed the
pthread_mutex_t in FILE directly already. This does mean that changing
pthread_mutex_t will change the ABI of FILE, but I think it is not an
incompatible change as it should not affect the "public" fields accessed via
macros.
--
John Baldwin
More information about the svn-src-user
mailing list