123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213 |
- /* Copyright (c) 2010, 2012, Oracle and/or its affiliates. All rights reserved.
- 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_TABLE_H
- #define MYSQL_TABLE_H
- /**
- @file mysql/psi/mysql_table.h
- Instrumentation helpers for table io.
- */
- #include "mysql/psi/psi.h"
- /**
- @defgroup Table_instrumentation Table Instrumentation
- @ingroup Instrumentation_interface
- @{
- */
- #ifdef HAVE_PSI_TABLE_INTERFACE
- #define MYSQL_UNBIND_TABLE(handler) (handler)->unbind_psi()
- #define MYSQL_REBIND_TABLE(handler) (handler)->rebind_psi()
- #define PSI_CALL_unbind_table PSI_TABLE_CALL(unbind_table)
- #define PSI_CALL_rebind_table PSI_TABLE_CALL(rebind_table)
- #define PSI_CALL_open_table PSI_TABLE_CALL(open_table)
- #define PSI_CALL_close_table PSI_TABLE_CALL(close_table)
- #define PSI_CALL_get_table_share PSI_TABLE_CALL(get_table_share)
- #define PSI_CALL_release_table_share PSI_TABLE_CALL(release_table_share)
- #define PSI_CALL_drop_table_share PSI_TABLE_CALL(drop_table_share)
- #else
- #define MYSQL_UNBIND_TABLE(handler) do { } while(0)
- #define MYSQL_REBIND_TABLE(handler) do { } while(0)
- #define PSI_CALL_unbind_table(A1) do { } while(0)
- #define PSI_CALL_rebind_table(A1,A2,A3) NULL
- #define PSI_CALL_close_table(A1) do { } while(0)
- #define PSI_CALL_open_table(A1,A2) NULL
- #define PSI_CALL_get_table_share(A1,A2) NULL
- #define PSI_CALL_release_table_share(A1) do { } while(0)
- #define PSI_CALL_drop_table_share(A1,A2,A3,A4,A5) do { } while(0)
- #endif
- /**
- @def MYSQL_TABLE_WAIT_VARIABLES
- Instrumentation helper for table waits.
- This instrumentation declares local variables.
- Do not use a ';' after this macro
- @param LOCKER the locker
- @param STATE the locker state
- @sa MYSQL_START_TABLE_IO_WAIT.
- @sa MYSQL_END_TABLE_IO_WAIT.
- @sa MYSQL_START_TABLE_LOCK_WAIT.
- @sa MYSQL_END_TABLE_LOCK_WAIT.
- */
- #ifdef HAVE_PSI_TABLE_INTERFACE
- #define MYSQL_TABLE_WAIT_VARIABLES(LOCKER, STATE) \
- struct PSI_table_locker* LOCKER; \
- PSI_table_locker_state STATE;
- #else
- #define MYSQL_TABLE_WAIT_VARIABLES(LOCKER, STATE)
- #endif
- /**
- @def MYSQL_TABLE_IO_WAIT
- Instrumentation helper for table io_waits.
- This instrumentation marks the start of a wait event.
- @param PSI the instrumented table
- @param OP the table operation to be performed
- @param INDEX the table index used if any, or MAY_KEY.
- @param FLAGS per table operation flags.
- @sa MYSQL_END_TABLE_WAIT.
- */
- #ifdef HAVE_PSI_TABLE_INTERFACE
- #define MYSQL_TABLE_IO_WAIT(PSI, OP, INDEX, FLAGS, PAYLOAD) \
- { \
- if (PSI != NULL) \
- { \
- PSI_table_locker *locker; \
- PSI_table_locker_state state; \
- locker= PSI_TABLE_CALL(start_table_io_wait) \
- (& state, PSI, OP, INDEX, __FILE__, __LINE__); \
- PAYLOAD \
- if (locker != NULL) \
- PSI_TABLE_CALL(end_table_io_wait)(locker); \
- } \
- else \
- { \
- PAYLOAD \
- } \
- }
- #else
- #define MYSQL_TABLE_IO_WAIT(PSI, OP, INDEX, FLAGS, PAYLOAD) \
- PAYLOAD
- #endif
- /**
- @def MYSQL_TABLE_LOCK_WAIT
- Instrumentation helper for table io_waits.
- This instrumentation marks the start of a wait event.
- @param PSI the instrumented table
- @param OP the table operation to be performed
- @param INDEX the table index used if any, or MAY_KEY.
- @param FLAGS per table operation flags.
- @sa MYSQL_END_TABLE_WAIT.
- */
- #ifdef HAVE_PSI_TABLE_INTERFACE
- #define MYSQL_TABLE_LOCK_WAIT(PSI, OP, FLAGS, PAYLOAD) \
- { \
- if (PSI != NULL) \
- { \
- PSI_table_locker *locker; \
- PSI_table_locker_state state; \
- locker= PSI_TABLE_CALL(start_table_lock_wait) \
- (& state, PSI, OP, FLAGS, __FILE__, __LINE__); \
- PAYLOAD \
- if (locker != NULL) \
- PSI_TABLE_CALL(end_table_lock_wait)(locker); \
- } \
- else \
- { \
- PAYLOAD \
- } \
- }
- #else
- #define MYSQL_TABLE_LOCK_WAIT(PSI, OP, FLAGS, PAYLOAD) \
- PAYLOAD
- #endif
- /**
- @def MYSQL_START_TABLE_LOCK_WAIT
- Instrumentation helper for table lock waits.
- This instrumentation marks the start of a wait event.
- @param LOCKER the locker
- @param STATE the locker state
- @param PSI the instrumented table
- @param OP the table operation to be performed
- @param FLAGS per table operation flags.
- @sa MYSQL_END_TABLE_LOCK_WAIT.
- */
- #ifdef HAVE_PSI_TABLE_INTERFACE
- #define MYSQL_START_TABLE_LOCK_WAIT(LOCKER, STATE, PSI, OP, FLAGS) \
- LOCKER= inline_mysql_start_table_lock_wait(STATE, PSI, \
- OP, FLAGS, __FILE__, __LINE__)
- #else
- #define MYSQL_START_TABLE_LOCK_WAIT(LOCKER, STATE, PSI, OP, FLAGS) \
- do {} while (0)
- #endif
- /**
- @def MYSQL_END_TABLE_LOCK_WAIT
- Instrumentation helper for table lock waits.
- This instrumentation marks the end of a wait event.
- @param LOCKER the locker
- @sa MYSQL_START_TABLE_LOCK_WAIT.
- */
- #ifdef HAVE_PSI_TABLE_INTERFACE
- #define MYSQL_END_TABLE_LOCK_WAIT(LOCKER) \
- inline_mysql_end_table_lock_wait(LOCKER)
- #else
- #define MYSQL_END_TABLE_LOCK_WAIT(LOCKER) \
- do {} while (0)
- #endif
- #ifdef HAVE_PSI_TABLE_INTERFACE
- /**
- Instrumentation calls for MYSQL_START_TABLE_LOCK_WAIT.
- @sa MYSQL_END_TABLE_LOCK_WAIT.
- */
- static inline struct PSI_table_locker *
- inline_mysql_start_table_lock_wait(PSI_table_locker_state *state,
- struct PSI_table *psi,
- enum PSI_table_lock_operation op,
- ulong flags, const char *src_file, int src_line)
- {
- if (psi != NULL)
- {
- struct PSI_table_locker *locker;
- locker= PSI_TABLE_CALL(start_table_lock_wait)
- (state, psi, op, flags, src_file, src_line);
- return locker;
- }
- return NULL;
- }
- /**
- Instrumentation calls for MYSQL_END_TABLE_LOCK_WAIT.
- @sa MYSQL_START_TABLE_LOCK_WAIT.
- */
- static inline void
- inline_mysql_end_table_lock_wait(struct PSI_table_locker *locker)
- {
- if (locker != NULL)
- PSI_TABLE_CALL(end_table_lock_wait)(locker);
- }
- #endif
- /** @} (end of group Table_instrumentation) */
- #endif
|