12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271 |
- /* Copyright (c) 2008, 2013, Oracle and/or its affiliates.
- This program is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; version 2 of the License.
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
- You should have received a copy of the GNU General Public License
- along with this program; if not, write to the Free Software Foundation,
- 51 Franklin Street, Suite 500, Boston, MA 02110-1335 USA */
- #ifndef MYSQL_THREAD_H
- #define MYSQL_THREAD_H
- /**
- @file mysql/psi/mysql_thread.h
- Instrumentation helpers for mysys threads, mutexes,
- read write locks and conditions.
- This header file provides the necessary declarations
- to use the mysys thread API with the performance schema instrumentation.
- In some compilers (SunStudio), 'static inline' functions, when declared
- but not used, are not optimized away (because they are unused) by default,
- so that including a static inline function from a header file does
- create unwanted dependencies, causing unresolved symbols at link time.
- Other compilers, like gcc, optimize these dependencies by default.
- Since the instrumented APIs declared here are wrapper on top
- of my_pthread / safemutex / etc APIs,
- including mysql/psi/mysql_thread.h assumes that
- the dependency on my_pthread and safemutex already exists.
- */
- /*
- Note: there are several orthogonal dimensions here.
- Dimension 1: Instrumentation
- HAVE_PSI_INTERFACE is defined when the instrumentation is compiled in.
- This may happen both in debug or production builds.
- Dimension 2: Debug
- SAFE_MUTEX is defined when debug is compiled in.
- This may happen both with and without instrumentation.
- Dimension 3: Platform
- Mutexes are implemented with one of:
- - the pthread library
- - fast mutexes
- - window apis
- This is implemented by various macro definitions in my_pthread.h
- This causes complexity with '#ifdef'-ery that can't be avoided.
- */
- #include "mysql/psi/psi.h"
- /**
- @defgroup Thread_instrumentation Thread Instrumentation
- @ingroup Instrumentation_interface
- @{
- */
- /**
- An instrumented mutex structure.
- @sa mysql_mutex_t
- */
- struct st_mysql_mutex
- {
- /** The real mutex. */
- #ifdef SAFE_MUTEX
- safe_mutex_t m_mutex;
- #elif defined(MY_PTHREAD_FASTMUTEX)
- my_pthread_fastmutex_t m_mutex;
- #else
- pthread_mutex_t m_mutex;
- #endif
- /**
- The instrumentation hook.
- Note that this hook is not conditionally defined,
- for binary compatibility of the @c mysql_mutex_t interface.
- */
- struct PSI_mutex *m_psi;
- };
- /**
- Type of an instrumented mutex.
- @c mysql_mutex_t is a drop-in replacement for @c pthread_mutex_t.
- @sa mysql_mutex_assert_owner
- @sa mysql_mutex_assert_not_owner
- @sa mysql_mutex_init
- @sa mysql_mutex_lock
- @sa mysql_mutex_unlock
- @sa mysql_mutex_destroy
- */
- typedef struct st_mysql_mutex mysql_mutex_t;
- /**
- An instrumented rwlock structure.
- @sa mysql_rwlock_t
- */
- struct st_mysql_rwlock
- {
- /** The real rwlock */
- rw_lock_t m_rwlock;
- /**
- The instrumentation hook.
- Note that this hook is not conditionally defined,
- for binary compatibility of the @c mysql_rwlock_t interface.
- */
- struct PSI_rwlock *m_psi;
- };
- /**
- An instrumented prlock structure.
- @sa mysql_prlock_t
- */
- struct st_mysql_prlock
- {
- /** The real prlock */
- rw_pr_lock_t m_prlock;
- /**
- The instrumentation hook.
- Note that this hook is not conditionally defined,
- for binary compatibility of the @c mysql_rwlock_t interface.
- */
- struct PSI_rwlock *m_psi;
- };
- /**
- Type of an instrumented rwlock.
- @c mysql_rwlock_t is a drop-in replacement for @c pthread_rwlock_t.
- @sa mysql_rwlock_init
- @sa mysql_rwlock_rdlock
- @sa mysql_rwlock_tryrdlock
- @sa mysql_rwlock_wrlock
- @sa mysql_rwlock_trywrlock
- @sa mysql_rwlock_unlock
- @sa mysql_rwlock_destroy
- */
- typedef struct st_mysql_rwlock mysql_rwlock_t;
- /**
- Type of an instrumented prlock.
- A prlock is a read write lock that 'prefers readers' (pr).
- @c mysql_prlock_t is a drop-in replacement for @c rw_pr_lock_t.
- @sa mysql_prlock_init
- @sa mysql_prlock_rdlock
- @sa mysql_prlock_wrlock
- @sa mysql_prlock_unlock
- @sa mysql_prlock_destroy
- */
- typedef struct st_mysql_prlock mysql_prlock_t;
- /**
- An instrumented cond structure.
- @sa mysql_cond_t
- */
- struct st_mysql_cond
- {
- /** The real condition */
- pthread_cond_t m_cond;
- /**
- The instrumentation hook.
- Note that this hook is not conditionally defined,
- for binary compatibility of the @c mysql_cond_t interface.
- */
- struct PSI_cond *m_psi;
- };
- /**
- Type of an instrumented condition.
- @c mysql_cond_t is a drop-in replacement for @c pthread_cond_t.
- @sa mysql_cond_init
- @sa mysql_cond_wait
- @sa mysql_cond_timedwait
- @sa mysql_cond_signal
- @sa mysql_cond_broadcast
- @sa mysql_cond_destroy
- */
- typedef struct st_mysql_cond mysql_cond_t;
- /*
- Consider the following code:
- static inline void foo() { bar(); }
- when foo() is never called.
- With gcc, foo() is a local static function, so the dependencies
- are optimized away at compile time, and there is no dependency on bar().
- With other compilers (HP, Sun Studio), the function foo() implementation
- is compiled, and bar() needs to be present to link.
- Due to the existing header dependencies in MySQL code, this header file
- is sometime used when it is not needed, which in turn cause link failures
- on some platforms.
- The proper fix would be to cut these extra dependencies in the calling code.
- DISABLE_MYSQL_THREAD_H is a work around to limit dependencies.
- DISABLE_MYSQL_PRLOCK_H is similar, and is used to disable specifically
- the prlock wrappers.
- */
- #ifndef DISABLE_MYSQL_THREAD_H
- /**
- @def mysql_mutex_assert_owner(M)
- Wrapper, to use safe_mutex_assert_owner with instrumented mutexes.
- @c mysql_mutex_assert_owner is a drop-in replacement
- for @c safe_mutex_assert_owner.
- */
- #define mysql_mutex_assert_owner(M) \
- safe_mutex_assert_owner(&(M)->m_mutex)
- /**
- @def mysql_mutex_assert_not_owner(M)
- Wrapper, to use safe_mutex_assert_not_owner with instrumented mutexes.
- @c mysql_mutex_assert_not_owner is a drop-in replacement
- for @c safe_mutex_assert_not_owner.
- */
- #define mysql_mutex_assert_not_owner(M) \
- safe_mutex_assert_not_owner(&(M)->m_mutex)
- #define mysql_mutex_setflags(M, F) \
- safe_mutex_setflags(&(M)->m_mutex, (F))
- /** Wrappers for instrumented prlock objects. */
- #define mysql_prlock_assert_write_owner(M) \
- rw_pr_lock_assert_write_owner(&(M)->m_prlock)
- #define mysql_prlock_assert_not_write_owner(M) \
- rw_pr_lock_assert_not_write_owner(&(M)->m_prlock)
- /**
- @def mysql_mutex_register(P1, P2, P3)
- Mutex registration.
- */
- #define mysql_mutex_register(P1, P2, P3) \
- inline_mysql_mutex_register(P1, P2, P3)
- /**
- @def mysql_mutex_init(K, M, A)
- Instrumented mutex_init.
- @c mysql_mutex_init is a replacement for @c pthread_mutex_init.
- @param K The PSI_mutex_key for this instrumented mutex
- @param M The mutex to initialize
- @param A Mutex attributes
- */
- #ifdef HAVE_PSI_MUTEX_INTERFACE
- #ifdef SAFE_MUTEX
- #define mysql_mutex_init(K, M, A) \
- inline_mysql_mutex_init(K, M, A, #M, __FILE__, __LINE__)
- #else
- #define mysql_mutex_init(K, M, A) \
- inline_mysql_mutex_init(K, M, A)
- #endif
- #else
- #ifdef SAFE_MUTEX
- #define mysql_mutex_init(K, M, A) \
- inline_mysql_mutex_init(M, A, #M, __FILE__, __LINE__)
- #else
- #define mysql_mutex_init(K, M, A) \
- inline_mysql_mutex_init(M, A)
- #endif
- #endif
- /**
- @def mysql_mutex_destroy(M)
- Instrumented mutex_destroy.
- @c mysql_mutex_destroy is a drop-in replacement
- for @c pthread_mutex_destroy.
- */
- #ifdef SAFE_MUTEX
- #define mysql_mutex_destroy(M) \
- inline_mysql_mutex_destroy(M, __FILE__, __LINE__)
- #else
- #define mysql_mutex_destroy(M) \
- inline_mysql_mutex_destroy(M)
- #endif
- /**
- @def mysql_mutex_lock(M)
- Instrumented mutex_lock.
- @c mysql_mutex_lock is a drop-in replacement for @c pthread_mutex_lock.
- @param M The mutex to lock
- */
- #if defined(SAFE_MUTEX) || defined (HAVE_PSI_MUTEX_INTERFACE)
- #define mysql_mutex_lock(M) \
- inline_mysql_mutex_lock(M, __FILE__, __LINE__)
- #else
- #define mysql_mutex_lock(M) \
- inline_mysql_mutex_lock(M)
- #endif
- /**
- @def mysql_mutex_trylock(M)
- Instrumented mutex_lock.
- @c mysql_mutex_trylock is a drop-in replacement
- for @c pthread_mutex_trylock.
- */
- #if defined(SAFE_MUTEX) || defined (HAVE_PSI_MUTEX_INTERFACE)
- #define mysql_mutex_trylock(M) \
- inline_mysql_mutex_trylock(M, __FILE__, __LINE__)
- #else
- #define mysql_mutex_trylock(M) \
- inline_mysql_mutex_trylock(M)
- #endif
- /**
- @def mysql_mutex_unlock(M)
- Instrumented mutex_unlock.
- @c mysql_mutex_unlock is a drop-in replacement for @c pthread_mutex_unlock.
- */
- #ifdef SAFE_MUTEX
- #define mysql_mutex_unlock(M) \
- inline_mysql_mutex_unlock(M, __FILE__, __LINE__)
- #else
- #define mysql_mutex_unlock(M) \
- inline_mysql_mutex_unlock(M)
- #endif
- /**
- @def mysql_rwlock_register(P1, P2, P3)
- Rwlock registration.
- */
- #define mysql_rwlock_register(P1, P2, P3) \
- inline_mysql_rwlock_register(P1, P2, P3)
- /**
- @def mysql_rwlock_init(K, RW)
- Instrumented rwlock_init.
- @c mysql_rwlock_init is a replacement for @c pthread_rwlock_init.
- Note that pthread_rwlockattr_t is not supported in MySQL.
- @param K The PSI_rwlock_key for this instrumented rwlock
- @param RW The rwlock to initialize
- */
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- #define mysql_rwlock_init(K, RW) inline_mysql_rwlock_init(K, RW)
- #else
- #define mysql_rwlock_init(K, RW) inline_mysql_rwlock_init(RW)
- #endif
- /**
- @def mysql_prlock_init(K, RW)
- Instrumented rw_pr_init.
- @c mysql_prlock_init is a replacement for @c rw_pr_init.
- @param K The PSI_rwlock_key for this instrumented prlock
- @param RW The prlock to initialize
- */
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- #define mysql_prlock_init(K, RW) inline_mysql_prlock_init(K, RW)
- #else
- #define mysql_prlock_init(K, RW) inline_mysql_prlock_init(RW)
- #endif
- /**
- @def mysql_rwlock_destroy(RW)
- Instrumented rwlock_destroy.
- @c mysql_rwlock_destroy is a drop-in replacement
- for @c pthread_rwlock_destroy.
- */
- #define mysql_rwlock_destroy(RW) inline_mysql_rwlock_destroy(RW)
- /**
- @def mysql_prlock_destroy(RW)
- Instrumented rw_pr_destroy.
- @c mysql_prlock_destroy is a drop-in replacement
- for @c rw_pr_destroy.
- */
- #define mysql_prlock_destroy(RW) inline_mysql_prlock_destroy(RW)
- /**
- @def mysql_rwlock_rdlock(RW)
- Instrumented rwlock_rdlock.
- @c mysql_rwlock_rdlock is a drop-in replacement
- for @c pthread_rwlock_rdlock.
- */
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- #define mysql_rwlock_rdlock(RW) \
- inline_mysql_rwlock_rdlock(RW, __FILE__, __LINE__)
- #else
- #define mysql_rwlock_rdlock(RW) \
- inline_mysql_rwlock_rdlock(RW)
- #endif
- /**
- @def mysql_prlock_rdlock(RW)
- Instrumented rw_pr_rdlock.
- @c mysql_prlock_rdlock is a drop-in replacement
- for @c rw_pr_rdlock.
- */
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- #define mysql_prlock_rdlock(RW) \
- inline_mysql_prlock_rdlock(RW, __FILE__, __LINE__)
- #else
- #define mysql_prlock_rdlock(RW) \
- inline_mysql_prlock_rdlock(RW)
- #endif
- /**
- @def mysql_rwlock_wrlock(RW)
- Instrumented rwlock_wrlock.
- @c mysql_rwlock_wrlock is a drop-in replacement
- for @c pthread_rwlock_wrlock.
- */
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- #define mysql_rwlock_wrlock(RW) \
- inline_mysql_rwlock_wrlock(RW, __FILE__, __LINE__)
- #else
- #define mysql_rwlock_wrlock(RW) \
- inline_mysql_rwlock_wrlock(RW)
- #endif
- /**
- @def mysql_prlock_wrlock(RW)
- Instrumented rw_pr_wrlock.
- @c mysql_prlock_wrlock is a drop-in replacement
- for @c rw_pr_wrlock.
- */
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- #define mysql_prlock_wrlock(RW) \
- inline_mysql_prlock_wrlock(RW, __FILE__, __LINE__)
- #else
- #define mysql_prlock_wrlock(RW) \
- inline_mysql_prlock_wrlock(RW)
- #endif
- /**
- @def mysql_rwlock_tryrdlock(RW)
- Instrumented rwlock_tryrdlock.
- @c mysql_rwlock_tryrdlock is a drop-in replacement
- for @c pthread_rwlock_tryrdlock.
- */
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- #define mysql_rwlock_tryrdlock(RW) \
- inline_mysql_rwlock_tryrdlock(RW, __FILE__, __LINE__)
- #else
- #define mysql_rwlock_tryrdlock(RW) \
- inline_mysql_rwlock_tryrdlock(RW)
- #endif
- /**
- @def mysql_rwlock_trywrlock(RW)
- Instrumented rwlock_trywrlock.
- @c mysql_rwlock_trywrlock is a drop-in replacement
- for @c pthread_rwlock_trywrlock.
- */
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- #define mysql_rwlock_trywrlock(RW) \
- inline_mysql_rwlock_trywrlock(RW, __FILE__, __LINE__)
- #else
- #define mysql_rwlock_trywrlock(RW) \
- inline_mysql_rwlock_trywrlock(RW)
- #endif
- /**
- @def mysql_rwlock_unlock(RW)
- Instrumented rwlock_unlock.
- @c mysql_rwlock_unlock is a drop-in replacement
- for @c pthread_rwlock_unlock.
- */
- #define mysql_rwlock_unlock(RW) inline_mysql_rwlock_unlock(RW)
- /**
- @def mysql_prlock_unlock(RW)
- Instrumented rw_pr_unlock.
- @c mysql_prlock_unlock is a drop-in replacement
- for @c rw_pr_unlock.
- */
- #define mysql_prlock_unlock(RW) inline_mysql_prlock_unlock(RW)
- /**
- @def mysql_cond_register(P1, P2, P3)
- Cond registration.
- */
- #define mysql_cond_register(P1, P2, P3) \
- inline_mysql_cond_register(P1, P2, P3)
- /**
- @def mysql_cond_init(K, C, A)
- Instrumented cond_init.
- @c mysql_cond_init is a replacement for @c pthread_cond_init.
- @param C The cond to initialize
- @param K The PSI_cond_key for this instrumented cond
- @param A Condition attributes
- */
- #ifdef HAVE_PSI_COND_INTERFACE
- #define mysql_cond_init(K, C, A) inline_mysql_cond_init(K, C, A)
- #else
- #define mysql_cond_init(K, C, A) inline_mysql_cond_init(C, A)
- #endif
- /**
- @def mysql_cond_destroy(C)
- Instrumented cond_destroy.
- @c mysql_cond_destroy is a drop-in replacement for @c pthread_cond_destroy.
- */
- #define mysql_cond_destroy(C) inline_mysql_cond_destroy(C)
- /**
- @def mysql_cond_wait(C)
- Instrumented cond_wait.
- @c mysql_cond_wait is a drop-in replacement for @c pthread_cond_wait.
- */
- #ifdef HAVE_PSI_COND_INTERFACE
- #define mysql_cond_wait(C, M) \
- inline_mysql_cond_wait(C, M, __FILE__, __LINE__)
- #else
- #define mysql_cond_wait(C, M) \
- inline_mysql_cond_wait(C, M)
- #endif
- /**
- @def mysql_cond_timedwait(C, M, W)
- Instrumented cond_timedwait.
- @c mysql_cond_timedwait is a drop-in replacement
- for @c pthread_cond_timedwait.
- */
- #ifdef HAVE_PSI_COND_INTERFACE
- #define mysql_cond_timedwait(C, M, W) \
- inline_mysql_cond_timedwait(C, M, W, __FILE__, __LINE__)
- #else
- #define mysql_cond_timedwait(C, M, W) \
- inline_mysql_cond_timedwait(C, M, W)
- #endif
- /**
- @def mysql_cond_signal(C)
- Instrumented cond_signal.
- @c mysql_cond_signal is a drop-in replacement for @c pthread_cond_signal.
- */
- #define mysql_cond_signal(C) inline_mysql_cond_signal(C)
- /**
- @def mysql_cond_broadcast(C)
- Instrumented cond_broadcast.
- @c mysql_cond_broadcast is a drop-in replacement
- for @c pthread_cond_broadcast.
- */
- #define mysql_cond_broadcast(C) inline_mysql_cond_broadcast(C)
- /**
- @def mysql_thread_register(P1, P2, P3)
- Thread registration.
- */
- #define mysql_thread_register(P1, P2, P3) \
- inline_mysql_thread_register(P1, P2, P3)
- /**
- @def mysql_thread_create(K, P1, P2, P3, P4)
- Instrumented pthread_create.
- This function creates both the thread instrumentation and a thread.
- @c mysql_thread_create is a replacement for @c pthread_create.
- The parameter P4 (or, if it is NULL, P1) will be used as the
- instrumented thread "indentity".
- Providing a P1 / P4 parameter with a different value for each call
- will on average improve performances, since this thread identity value
- is used internally to randomize access to data and prevent contention.
- This is optional, and the improvement is not guaranteed, only statistical.
- @param K The PSI_thread_key for this instrumented thread
- @param P1 pthread_create parameter 1
- @param P2 pthread_create parameter 2
- @param P3 pthread_create parameter 3
- @param P4 pthread_create parameter 4
- */
- #ifdef HAVE_PSI_THREAD_INTERFACE
- #define mysql_thread_create(K, P1, P2, P3, P4) \
- inline_mysql_thread_create(K, P1, P2, P3, P4)
- #else
- #define mysql_thread_create(K, P1, P2, P3, P4) \
- pthread_create(P1, P2, P3, P4)
- #endif
- /**
- @def mysql_thread_set_psi_id(I)
- Set the thread indentifier for the instrumentation.
- @param I The thread identifier
- */
- #ifdef HAVE_PSI_THREAD_INTERFACE
- #define mysql_thread_set_psi_id(I) inline_mysql_thread_set_psi_id(I)
- #else
- #define mysql_thread_set_psi_id(I) do {} while (0)
- #endif
- static inline void inline_mysql_mutex_register(
- #ifdef HAVE_PSI_MUTEX_INTERFACE
- const char *category,
- PSI_mutex_info *info,
- int count
- #else
- const char *category __attribute__ ((unused)),
- void *info __attribute__ ((unused)),
- int count __attribute__ ((unused))
- #endif
- )
- {
- #ifdef HAVE_PSI_MUTEX_INTERFACE
- PSI_MUTEX_CALL(register_mutex)(category, info, count);
- #endif
- }
- static inline int inline_mysql_mutex_init(
- #ifdef HAVE_PSI_MUTEX_INTERFACE
- PSI_mutex_key key,
- #endif
- mysql_mutex_t *that,
- const pthread_mutexattr_t *attr
- #ifdef SAFE_MUTEX
- , const char *src_name, const char *src_file, uint src_line
- #endif
- )
- {
- #ifdef HAVE_PSI_MUTEX_INTERFACE
- that->m_psi= PSI_MUTEX_CALL(init_mutex)(key, &that->m_mutex);
- #else
- that->m_psi= NULL;
- #endif
- #ifdef SAFE_MUTEX
- return safe_mutex_init(&that->m_mutex, attr, src_name, src_file, src_line);
- #elif defined(MY_PTHREAD_FASTMUTEX)
- return my_pthread_fastmutex_init(&that->m_mutex, attr);
- #else
- return pthread_mutex_init(&that->m_mutex, attr);
- #endif
- }
- static inline int inline_mysql_mutex_destroy(
- mysql_mutex_t *that
- #ifdef SAFE_MUTEX
- , const char *src_file, uint src_line
- #endif
- )
- {
- #ifdef HAVE_PSI_MUTEX_INTERFACE
- if (that->m_psi != NULL)
- {
- PSI_MUTEX_CALL(destroy_mutex)(that->m_psi);
- that->m_psi= NULL;
- }
- #endif
- #ifdef SAFE_MUTEX
- return safe_mutex_destroy(&that->m_mutex, src_file, src_line);
- #elif defined(MY_PTHREAD_FASTMUTEX)
- return pthread_mutex_destroy(&that->m_mutex.mutex);
- #else
- return pthread_mutex_destroy(&that->m_mutex);
- #endif
- }
- static inline int inline_mysql_mutex_lock(
- mysql_mutex_t *that
- #if defined(SAFE_MUTEX) || defined (HAVE_PSI_MUTEX_INTERFACE)
- , const char *src_file, uint src_line
- #endif
- )
- {
- int result;
- #ifdef HAVE_PSI_MUTEX_INTERFACE
- if (that->m_psi != NULL)
- {
- /* Instrumentation start */
- PSI_mutex_locker *locker;
- PSI_mutex_locker_state state;
- locker= PSI_MUTEX_CALL(start_mutex_wait)(&state, that->m_psi,
- PSI_MUTEX_LOCK, src_file, src_line);
- /* Instrumented code */
- #ifdef SAFE_MUTEX
- result= safe_mutex_lock(&that->m_mutex, FALSE, src_file, src_line);
- #elif defined(MY_PTHREAD_FASTMUTEX)
- result= my_pthread_fastmutex_lock(&that->m_mutex);
- #else
- result= pthread_mutex_lock(&that->m_mutex);
- #endif
- /* Instrumentation end */
- if (locker != NULL)
- PSI_MUTEX_CALL(end_mutex_wait)(locker, result);
- return result;
- }
- #endif
- /* Non instrumented code */
- #ifdef SAFE_MUTEX
- result= safe_mutex_lock(&that->m_mutex, FALSE, src_file, src_line);
- #elif defined(MY_PTHREAD_FASTMUTEX)
- result= my_pthread_fastmutex_lock(&that->m_mutex);
- #else
- result= pthread_mutex_lock(&that->m_mutex);
- #endif
- return result;
- }
- static inline int inline_mysql_mutex_trylock(
- mysql_mutex_t *that
- #if defined(SAFE_MUTEX) || defined (HAVE_PSI_MUTEX_INTERFACE)
- , const char *src_file, uint src_line
- #endif
- )
- {
- int result;
- #ifdef HAVE_PSI_MUTEX_INTERFACE
- if (that->m_psi != NULL)
- {
- /* Instrumentation start */
- PSI_mutex_locker *locker;
- PSI_mutex_locker_state state;
- locker= PSI_MUTEX_CALL(start_mutex_wait)(&state, that->m_psi,
- PSI_MUTEX_TRYLOCK, src_file, src_line);
- /* Instrumented code */
- #ifdef SAFE_MUTEX
- result= safe_mutex_lock(&that->m_mutex, TRUE, src_file, src_line);
- #elif defined(MY_PTHREAD_FASTMUTEX)
- result= pthread_mutex_trylock(&that->m_mutex.mutex);
- #else
- result= pthread_mutex_trylock(&that->m_mutex);
- #endif
- /* Instrumentation end */
- if (locker != NULL)
- PSI_MUTEX_CALL(end_mutex_wait)(locker, result);
- return result;
- }
- #endif
- /* Non instrumented code */
- #ifdef SAFE_MUTEX
- result= safe_mutex_lock(&that->m_mutex, TRUE, src_file, src_line);
- #elif defined(MY_PTHREAD_FASTMUTEX)
- result= pthread_mutex_trylock(&that->m_mutex.mutex);
- #else
- result= pthread_mutex_trylock(&that->m_mutex);
- #endif
- return result;
- }
- static inline int inline_mysql_mutex_unlock(
- mysql_mutex_t *that
- #ifdef SAFE_MUTEX
- , const char *src_file, uint src_line
- #endif
- )
- {
- int result;
- #ifdef HAVE_PSI_MUTEX_INTERFACE
- if (that->m_psi != NULL)
- PSI_MUTEX_CALL(unlock_mutex)(that->m_psi);
- #endif
- #ifdef SAFE_MUTEX
- result= safe_mutex_unlock(&that->m_mutex, src_file, src_line);
- #elif defined(MY_PTHREAD_FASTMUTEX)
- result= pthread_mutex_unlock(&that->m_mutex.mutex);
- #else
- result= pthread_mutex_unlock(&that->m_mutex);
- #endif
- return result;
- }
- static inline void inline_mysql_rwlock_register(
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- const char *category,
- PSI_rwlock_info *info,
- int count
- #else
- const char *category __attribute__ ((unused)),
- void *info __attribute__ ((unused)),
- int count __attribute__ ((unused))
- #endif
- )
- {
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- PSI_RWLOCK_CALL(register_rwlock)(category, info, count);
- #endif
- }
- static inline int inline_mysql_rwlock_init(
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- PSI_rwlock_key key,
- #endif
- mysql_rwlock_t *that)
- {
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- that->m_psi= PSI_RWLOCK_CALL(init_rwlock)(key, &that->m_rwlock);
- #else
- that->m_psi= NULL;
- #endif
- /*
- pthread_rwlockattr_t is not used in MySQL.
- */
- return my_rwlock_init(&that->m_rwlock, NULL);
- }
- #ifndef DISABLE_MYSQL_PRLOCK_H
- static inline int inline_mysql_prlock_init(
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- PSI_rwlock_key key,
- #endif
- mysql_prlock_t *that)
- {
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- that->m_psi= PSI_RWLOCK_CALL(init_rwlock)(key, &that->m_prlock);
- #else
- that->m_psi= NULL;
- #endif
- return rw_pr_init(&that->m_prlock);
- }
- #endif
- static inline int inline_mysql_rwlock_destroy(
- mysql_rwlock_t *that)
- {
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- if (that->m_psi != NULL)
- {
- PSI_RWLOCK_CALL(destroy_rwlock)(that->m_psi);
- that->m_psi= NULL;
- }
- #endif
- return rwlock_destroy(&that->m_rwlock);
- }
- #ifndef DISABLE_MYSQL_PRLOCK_H
- static inline int inline_mysql_prlock_destroy(
- mysql_prlock_t *that)
- {
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- if (that->m_psi != NULL)
- {
- PSI_RWLOCK_CALL(destroy_rwlock)(that->m_psi);
- that->m_psi= NULL;
- }
- #endif
- return rw_pr_destroy(&that->m_prlock);
- }
- #endif
- static inline int inline_mysql_rwlock_rdlock(
- mysql_rwlock_t *that
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- , const char *src_file, uint src_line
- #endif
- )
- {
- int result;
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- if (that->m_psi != NULL)
- {
- /* Instrumentation start */
- PSI_rwlock_locker *locker;
- PSI_rwlock_locker_state state;
- locker= PSI_RWLOCK_CALL(start_rwlock_rdwait)(&state, that->m_psi,
- PSI_RWLOCK_READLOCK, src_file, src_line);
- /* Instrumented code */
- result= rw_rdlock(&that->m_rwlock);
- /* Instrumentation end */
- if (locker != NULL)
- PSI_RWLOCK_CALL(end_rwlock_rdwait)(locker, result);
- return result;
- }
- #endif
- /* Non instrumented code */
- result= rw_rdlock(&that->m_rwlock);
- return result;
- }
- #ifndef DISABLE_MYSQL_PRLOCK_H
- static inline int inline_mysql_prlock_rdlock(
- mysql_prlock_t *that
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- , const char *src_file, uint src_line
- #endif
- )
- {
- int result;
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- if (that->m_psi != NULL)
- {
- /* Instrumentation start */
- PSI_rwlock_locker *locker;
- PSI_rwlock_locker_state state;
- locker= PSI_RWLOCK_CALL(start_rwlock_rdwait)(&state, that->m_psi,
- PSI_RWLOCK_READLOCK, src_file, src_line);
- /* Instrumented code */
- result= rw_pr_rdlock(&that->m_prlock);
- /* Instrumentation end */
- if (locker != NULL)
- PSI_RWLOCK_CALL(end_rwlock_rdwait)(locker, result);
- return result;
- }
- #endif
- /* Non instrumented code */
- result= rw_pr_rdlock(&that->m_prlock);
- return result;
- }
- #endif
- static inline int inline_mysql_rwlock_wrlock(
- mysql_rwlock_t *that
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- , const char *src_file, uint src_line
- #endif
- )
- {
- int result;
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- if (that->m_psi != NULL)
- {
- /* Instrumentation start */
- PSI_rwlock_locker *locker;
- PSI_rwlock_locker_state state;
- locker= PSI_RWLOCK_CALL(start_rwlock_wrwait)(&state, that->m_psi,
- PSI_RWLOCK_WRITELOCK, src_file, src_line);
- /* Instrumented code */
- result= rw_wrlock(&that->m_rwlock);
- /* Instrumentation end */
- if (locker != NULL)
- PSI_RWLOCK_CALL(end_rwlock_wrwait)(locker, result);
- return result;
- }
- #endif
- /* Non instrumented code */
- result= rw_wrlock(&that->m_rwlock);
- return result;
- }
- #ifndef DISABLE_MYSQL_PRLOCK_H
- static inline int inline_mysql_prlock_wrlock(
- mysql_prlock_t *that
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- , const char *src_file, uint src_line
- #endif
- )
- {
- int result;
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- if (that->m_psi != NULL)
- {
- /* Instrumentation start */
- PSI_rwlock_locker *locker;
- PSI_rwlock_locker_state state;
- locker= PSI_RWLOCK_CALL(start_rwlock_wrwait)(&state, that->m_psi,
- PSI_RWLOCK_WRITELOCK, src_file, src_line);
- /* Instrumented code */
- result= rw_pr_wrlock(&that->m_prlock);
- /* Instrumentation end */
- if (locker != NULL)
- PSI_RWLOCK_CALL(end_rwlock_wrwait)(locker, result);
- return result;
- }
- #endif
- /* Non instrumented code */
- result= rw_pr_wrlock(&that->m_prlock);
- return result;
- }
- #endif
- static inline int inline_mysql_rwlock_tryrdlock(
- mysql_rwlock_t *that
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- , const char *src_file, uint src_line
- #endif
- )
- {
- int result;
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- if (that->m_psi != NULL)
- {
- /* Instrumentation start */
- PSI_rwlock_locker *locker;
- PSI_rwlock_locker_state state;
- locker= PSI_RWLOCK_CALL(start_rwlock_rdwait)(&state, that->m_psi,
- PSI_RWLOCK_TRYREADLOCK, src_file, src_line);
- /* Instrumented code */
- result= rw_tryrdlock(&that->m_rwlock);
- /* Instrumentation end */
- if (locker != NULL)
- PSI_RWLOCK_CALL(end_rwlock_rdwait)(locker, result);
- return result;
- }
- #endif
- /* Non instrumented code */
- result= rw_tryrdlock(&that->m_rwlock);
- return result;
- }
- static inline int inline_mysql_rwlock_trywrlock(
- mysql_rwlock_t *that
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- , const char *src_file, uint src_line
- #endif
- )
- {
- int result;
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- if (that->m_psi != NULL)
- {
- /* Instrumentation start */
- PSI_rwlock_locker *locker;
- PSI_rwlock_locker_state state;
- locker= PSI_RWLOCK_CALL(start_rwlock_wrwait)(&state, that->m_psi,
- PSI_RWLOCK_TRYWRITELOCK, src_file, src_line);
- /* Instrumented code */
- result= rw_trywrlock(&that->m_rwlock);
- /* Instrumentation end */
- if (locker != NULL)
- PSI_RWLOCK_CALL(end_rwlock_wrwait)(locker, result);
- return result;
- }
- #endif
- /* Non instrumented code */
- result= rw_trywrlock(&that->m_rwlock);
- return result;
- }
- static inline int inline_mysql_rwlock_unlock(
- mysql_rwlock_t *that)
- {
- int result;
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- if (that->m_psi != NULL)
- PSI_RWLOCK_CALL(unlock_rwlock)(that->m_psi);
- #endif
- result= rw_unlock(&that->m_rwlock);
- return result;
- }
- #ifndef DISABLE_MYSQL_PRLOCK_H
- static inline int inline_mysql_prlock_unlock(
- mysql_prlock_t *that)
- {
- int result;
- #ifdef HAVE_PSI_RWLOCK_INTERFACE
- if (that->m_psi != NULL)
- PSI_RWLOCK_CALL(unlock_rwlock)(that->m_psi);
- #endif
- result= rw_pr_unlock(&that->m_prlock);
- return result;
- }
- #endif
- static inline void inline_mysql_cond_register(
- #ifdef HAVE_PSI_COND_INTERFACE
- const char *category,
- PSI_cond_info *info,
- int count
- #else
- const char *category __attribute__ ((unused)),
- void *info __attribute__ ((unused)),
- int count __attribute__ ((unused))
- #endif
- )
- {
- #ifdef HAVE_PSI_COND_INTERFACE
- PSI_COND_CALL(register_cond)(category, info, count);
- #endif
- }
- static inline int inline_mysql_cond_init(
- #ifdef HAVE_PSI_COND_INTERFACE
- PSI_cond_key key,
- #endif
- mysql_cond_t *that,
- const pthread_condattr_t *attr)
- {
- #ifdef HAVE_PSI_COND_INTERFACE
- that->m_psi= PSI_COND_CALL(init_cond)(key, &that->m_cond);
- #else
- that->m_psi= NULL;
- #endif
- return pthread_cond_init(&that->m_cond, attr);
- }
- static inline int inline_mysql_cond_destroy(
- mysql_cond_t *that)
- {
- #ifdef HAVE_PSI_COND_INTERFACE
- if (that->m_psi != NULL)
- {
- PSI_COND_CALL(destroy_cond)(that->m_psi);
- that->m_psi= NULL;
- }
- #endif
- return pthread_cond_destroy(&that->m_cond);
- }
- static inline int inline_mysql_cond_wait(
- mysql_cond_t *that,
- mysql_mutex_t *mutex
- #ifdef HAVE_PSI_COND_INTERFACE
- , const char *src_file, uint src_line
- #endif
- )
- {
- int result;
- #ifdef HAVE_PSI_COND_INTERFACE
- if (that->m_psi != NULL)
- {
- /* Instrumentation start */
- PSI_cond_locker *locker;
- PSI_cond_locker_state state;
- locker= PSI_COND_CALL(start_cond_wait)(&state, that->m_psi, mutex->m_psi,
- PSI_COND_WAIT, src_file, src_line);
- /* Instrumented code */
- result= my_cond_wait(&that->m_cond, &mutex->m_mutex);
- /* Instrumentation end */
- if (locker != NULL)
- PSI_COND_CALL(end_cond_wait)(locker, result);
- return result;
- }
- #endif
- /* Non instrumented code */
- result= my_cond_wait(&that->m_cond, &mutex->m_mutex);
- return result;
- }
- static inline int inline_mysql_cond_timedwait(
- mysql_cond_t *that,
- mysql_mutex_t *mutex,
- const struct timespec *abstime
- #ifdef HAVE_PSI_COND_INTERFACE
- , const char *src_file, uint src_line
- #endif
- )
- {
- int result;
- #ifdef HAVE_PSI_COND_INTERFACE
- if (that->m_psi != NULL)
- {
- /* Instrumentation start */
- PSI_cond_locker *locker;
- PSI_cond_locker_state state;
- locker= PSI_COND_CALL(start_cond_wait)(&state, that->m_psi, mutex->m_psi,
- PSI_COND_TIMEDWAIT, src_file, src_line);
- /* Instrumented code */
- result= my_cond_timedwait(&that->m_cond, &mutex->m_mutex, abstime);
- /* Instrumentation end */
- if (locker != NULL)
- PSI_COND_CALL(end_cond_wait)(locker, result);
- return result;
- }
- #endif
- /* Non instrumented code */
- result= my_cond_timedwait(&that->m_cond, &mutex->m_mutex, abstime);
- return result;
- }
- static inline int inline_mysql_cond_signal(
- mysql_cond_t *that)
- {
- int result;
- #ifdef HAVE_PSI_COND_INTERFACE
- if (that->m_psi != NULL)
- PSI_COND_CALL(signal_cond)(that->m_psi);
- #endif
- result= pthread_cond_signal(&that->m_cond);
- return result;
- }
- static inline int inline_mysql_cond_broadcast(
- mysql_cond_t *that)
- {
- int result;
- #ifdef HAVE_PSI_COND_INTERFACE
- if (that->m_psi != NULL)
- PSI_COND_CALL(broadcast_cond)(that->m_psi);
- #endif
- result= pthread_cond_broadcast(&that->m_cond);
- return result;
- }
- static inline void inline_mysql_thread_register(
- #ifdef HAVE_PSI_THREAD_INTERFACE
- const char *category,
- PSI_thread_info *info,
- int count
- #else
- const char *category __attribute__ ((unused)),
- void *info __attribute__ ((unused)),
- int count __attribute__ ((unused))
- #endif
- )
- {
- #ifdef HAVE_PSI_THREAD_INTERFACE
- PSI_THREAD_CALL(register_thread)(category, info, count);
- #endif
- }
- #ifdef HAVE_PSI_THREAD_INTERFACE
- static inline int inline_mysql_thread_create(
- PSI_thread_key key,
- pthread_t *thread, const pthread_attr_t *attr,
- void *(*start_routine)(void*), void *arg)
- {
- int result;
- result= PSI_THREAD_CALL(spawn_thread)(key, thread, attr, start_routine, arg);
- return result;
- }
- static inline void inline_mysql_thread_set_psi_id(ulong id)
- {
- struct PSI_thread *psi= PSI_THREAD_CALL(get_thread)();
- PSI_THREAD_CALL(set_thread_id)(psi, id);
- }
- #endif
- #endif /* DISABLE_MYSQL_THREAD_H */
- /** @} (end of group Thread_instrumentation) */
- #endif
|