Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 31 Oct 2007 07:25:10 +0800
From:      David Xu <bsddiy@126.com>
To:        Ken Smith <kensmith@cse.Buffalo.EDU>
Cc:        src-committers@FreeBSD.org, cvs-src@FreeBSD.org, Kris Kennaway <kris@FreeBSD.org>, cvs-all@FreeBSD.org, Daniel Eischen <deischen@FreeBSD.org>, David Xu <davidxu@FreeBSD.org>
Subject:   Re: cvs commit: src/lib/libthr/thread thr_mutex.c	src/lib/libkse/thread thr_mutex.c src/include pthread.h
Message-ID:  <4727BD56.2060001@126.com>
In-Reply-To: <1193750770.25313.7.camel@opus.cse.buffalo.edu>
References:  <200710292101.l9TL1mAE049561@repoman.freebsd.org>	 <47268F17.1000106@freebsd.org>	 <Pine.GSO.4.64.0710292207140.19572@sea.ntplx.net>	 <4726E9AB.4050209@FreeBSD.org> <4726F130.2060709@freebsd.org>	 <4726F7E9.2060403@FreeBSD.org> <4726FB01.4060704@freebsd.org>	 <47270410.2020802@FreeBSD.org> <47272EC0.1030204@freebsd.org> <1193750770.25313.7.camel@opus.cse.buffalo.edu>

next in thread | previous in thread | raw e-mail | index | archive | help
Ken Smith wrote:
> On Tue, 2007-10-30 at 21:16 +0800, David Xu wrote:
>> Kris Kennaway wrote:
>>> PTHREAD_ADAPTIVE_MUTEX_INITIALIZER_NP is just in <pthread.h>.
>>>
>>> /*
>>>  * Static initialization values.
>>>  */
>>> #define PTHREAD_MUTEX_INITIALIZER       NULL
>>> #define PTHREAD_ADAPTIVE_MUTEX_INITIALIZER_NP   NULL
>>> #define PTHREAD_COND_INITIALIZER        NULL
>>> #define PTHREAD_RWLOCK_INITIALIZER      NULL
>>>
>>>>>> I remembered mysql uses this macro to initialize spin mutex, and you
>>>>>> indead needs a patch to let it work
>>>>>
>>>>> No, with the code I committed mysql detects and uses it out of the 
>>>>> box, without requiring any patches.  It is easy to measure the 
>>>>> resulting 30% performance improvement at high loads ;-)
>>>>>
>>>> see above, I didn't see any code set PTHREAD_MUTEX_ADAPTIVE_NP type.
>>> The code is already in mysql for use with glibc.  It basically does
>>>
>>> #ifdef PTHREAD_ADAPTIVE_MUTEX_INITIALIZER_NP
>>> /*
>>>  * Use PTHREAD_MUTEX_ADAPTIVE_NP for the mutexes we know will benefit
>>>  * from it
>>>  */
>>> ...
>>> #endif
>>>
>>> so it just works.
>>>
>> I can not find code in libthr setting mutex's member field m_type to
>> PTHREAD_MUTEX_ADAPTIVE_NP by your change, so how can it work as
>> expected ?
>>
> 
> Wouldn't you expect that it's mysql that's setting the mutex's member
> field?  Something like this chunk of code from mysql perhaps?
> 
> #ifdef PTHREAD_ADAPTIVE_MUTEX_INITIALIZER_NP
>   /*
>     Set mutex type to "fast" a.k.a "adaptive"
> 
>     In this case the thread may steal the mutex from some other thread
>     that is waiting for the same mutex.  This will save us some
>     context switches but may cause a thread to 'starve forever' while
>     waiting for the mutex (not likely if the code within the mutex is
>     short).
>   */
>   pthread_mutexattr_init(&my_fast_mutexattr);
>   pthread_mutexattr_settype(&my_fast_mutexattr,
>                             PTHREAD_MUTEX_ADAPTIVE_NP);
> #endif
> 

Yes, I saw the code before. but PTHREAD_ADAPTIVE_MUTEX_INITIALIZER_NP
also can be used as:

pthread_mutex_t mymutex = PTHREAD_ADAPTIVE_MUTEX_INITIALIZER_NP;

The above line initializes a mutex as adaptive mutex, but our
PTHREAD_ADAPTIVE_MUTEX_INITIALIZER_NP is defined as NULL, so obviously
it creates a confusion from begin, it is wrong.

Regards,
David Xu




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?4727BD56.2060001>