mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-31 02:46:29 +01:00 
			
		
		
		
	 55db59f16d
			
		
	
	
	55db59f16d
	
	
	
		
			
			PFS_atomic class contains wrappers around my_atomic_* operations, which
are macros to GNU atomic operations (__atomic_*). Due to different
implementations of compilers, clang may encounter errors when compiling
on x86_32 architecture.
The following functions are replaced with C++ std::atomic type in
performance schema code base:
  - PFS_atomic::store_*()
      -> my_atomic_store*
        -> __atomic_store_n()
    => std::atomic<T>::store()
  - PFS_atomic::load_*()
      -> my_atomic_load*
        -> __atomic_load_n()
    => std::atomic<T>::load()
  - PFS_atomic::add_*()
      -> my_atomic_add*
        -> __atomic_fetch_add()
    => std::atomic<T>::fetch_add()
  - PFS_atomic::cas_*()
    -> my_atomic_cas*
      -> __atomic_compare_exchange_n()
    => std::atomic<T>::compare_exchange_strong()
and PFS_atomic class could be dropped completely.
Note that in the wrapper memory order passed to original GNU atomic
extensions are hard-coded as `__ATOMIC_SEQ_CST`, which is equivalent to
`std::memory_order_seq_cst` in C++, and is the default parameter for
std::atomic_* functions.
All new code of the whole pull request, including one or several files
that are either new files or modified ones, are contributed under the
BSD-new license. I am contributing on behalf of my employer Amazon Web
Services.
		
	
			
		
			
				
	
	
		
			650 lines
		
	
	
	
		
			18 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			650 lines
		
	
	
	
		
			18 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /* Copyright (c) 2008, 2023, 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, version 2.0,
 | |
|   as published by the Free Software Foundation.
 | |
| 
 | |
|   This program is also distributed with certain software (including
 | |
|   but not limited to OpenSSL) that is licensed under separate terms,
 | |
|   as designated in a particular file or component or in included license
 | |
|   documentation.  The authors of MySQL hereby grant you an additional
 | |
|   permission to link the program and your derivative works with the
 | |
|   separately licensed software that they have included with MySQL.
 | |
| 
 | |
|   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, version 2.0, 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, Fifth Floor, Boston, MA 02110-1335 USA */
 | |
| 
 | |
| #ifndef PFS_INSTR_CLASS_H
 | |
| #define PFS_INSTR_CLASS_H
 | |
| 
 | |
| #include <atomic>
 | |
| 
 | |
| #include "my_global.h"
 | |
| #include "mysql_com.h"                          /* NAME_LEN */
 | |
| #include "lf.h"
 | |
| #include "pfs_global.h"
 | |
| #include "sql_array.h"
 | |
| 
 | |
| /**
 | |
|   @file storage/perfschema/pfs_instr_class.h
 | |
|   Performance schema instruments meta data (declarations).
 | |
| */
 | |
| 
 | |
| /**
 | |
|   Maximum length of an instrument name.
 | |
|   For example, 'wait/sync/mutex/sql/LOCK_open' is an instrument name.
 | |
| */
 | |
| #define PFS_MAX_INFO_NAME_LENGTH 128
 | |
| 
 | |
| /**
 | |
|   Maximum length of the 'full' prefix of an instrument name.
 | |
|   For example, for the instrument name 'wait/sync/mutex/sql/LOCK_open',
 | |
|   the full prefix is 'wait/sync/mutex/sql/', which in turn derives from
 | |
|   a prefix 'wait/sync/mutex' for mutexes, and a category of 'sql' for mutexes
 | |
|   of the sql layer in the server.
 | |
| */
 | |
| #define PFS_MAX_FULL_PREFIX_NAME_LENGTH 32
 | |
| 
 | |
| #include <my_sys.h>
 | |
| #include <mysql/psi/psi.h>
 | |
| #include "pfs_lock.h"
 | |
| #include "pfs_stat.h"
 | |
| #include "pfs_column_types.h"
 | |
| 
 | |
| struct PFS_global_param;
 | |
| struct PFS_table_share;
 | |
| class PFS_opaque_container_page;
 | |
| 
 | |
| /**
 | |
|   @addtogroup Performance_schema_buffers
 | |
|   @{
 | |
| */
 | |
| 
 | |
| extern my_bool pfs_enabled;
 | |
| extern enum_timer_name *class_timers[];
 | |
| 
 | |
| /** Key, naming a synch instrument (mutex, rwlock, cond). */
 | |
| typedef unsigned int PFS_sync_key;
 | |
| /** Key, naming a thread instrument. */
 | |
| typedef unsigned int PFS_thread_key;
 | |
| /** Key, naming a file instrument. */
 | |
| typedef unsigned int PFS_file_key;
 | |
| /** Key, naming a stage instrument. */
 | |
| typedef unsigned int PFS_stage_key;
 | |
| /** Key, naming a statement instrument. */
 | |
| typedef unsigned int PFS_statement_key;
 | |
| /** Key, naming a transaction instrument. */
 | |
| typedef unsigned int PFS_transaction_key;
 | |
| /** Key, naming a socket instrument. */
 | |
| typedef unsigned int PFS_socket_key;
 | |
| /** Key, naming a memory instrument. */
 | |
| typedef unsigned int PFS_memory_key;
 | |
| 
 | |
| enum PFS_class_type
 | |
| {
 | |
|   PFS_CLASS_NONE=        0,
 | |
|   PFS_CLASS_MUTEX=       1,
 | |
|   PFS_CLASS_RWLOCK=      2,
 | |
|   PFS_CLASS_COND=        3,
 | |
|   PFS_CLASS_FILE=        4,
 | |
|   PFS_CLASS_TABLE=       5,
 | |
|   PFS_CLASS_STAGE=       6,
 | |
|   PFS_CLASS_STATEMENT=   7,
 | |
|   PFS_CLASS_TRANSACTION= 8,
 | |
|   PFS_CLASS_SOCKET=      9,
 | |
|   PFS_CLASS_TABLE_IO=   10,
 | |
|   PFS_CLASS_TABLE_LOCK= 11,
 | |
|   PFS_CLASS_IDLE=       12,
 | |
|   PFS_CLASS_MEMORY=     13,
 | |
|   PFS_CLASS_METADATA=   14,
 | |
|   PFS_CLASS_LAST=       PFS_CLASS_METADATA,
 | |
|   PFS_CLASS_MAX=        PFS_CLASS_LAST + 1
 | |
| };
 | |
| 
 | |
| /** User-defined instrument configuration. */
 | |
| struct PFS_instr_config
 | |
| {
 | |
|   /* Instrument name. */
 | |
|   char *m_name;
 | |
|   /* Name length. */
 | |
|   uint m_name_length;
 | |
|   /** Enabled flag. */
 | |
|   bool m_enabled;
 | |
|   /** Timed flag. */
 | |
|   bool m_timed;
 | |
| };
 | |
| 
 | |
| typedef Dynamic_array<PFS_instr_config*> Pfs_instr_config_array;
 | |
| extern Pfs_instr_config_array *pfs_instr_config_array;
 | |
| 
 | |
| struct PFS_thread;
 | |
| 
 | |
| extern uint mutex_class_start;
 | |
| extern uint rwlock_class_start;
 | |
| extern uint cond_class_start;
 | |
| extern uint file_class_start;
 | |
| extern uint socket_class_start;
 | |
| extern uint wait_class_max;
 | |
| 
 | |
| /** Information for all instrumentation. */
 | |
| struct PFS_instr_class
 | |
| {
 | |
|   /** Class type */
 | |
|   PFS_class_type m_type;
 | |
|   /** True if this instrument is enabled. */
 | |
|   bool m_enabled;
 | |
|   /** True if this instrument is timed. */
 | |
|   bool m_timed;
 | |
|   /** Instrument flags. */
 | |
|   int m_flags;
 | |
|   /** Volatility index. */
 | |
|   int m_volatility;
 | |
|   /**
 | |
|     Instrument name index.
 | |
|     Self index in:
 | |
|     - EVENTS_WAITS_SUMMARY_*_BY_EVENT_NAME for waits
 | |
|     - EVENTS_STAGES_SUMMARY_*_BY_EVENT_NAME for stages
 | |
|     - EVENTS_STATEMENTS_SUMMARY_*_BY_EVENT_NAME for statements
 | |
|     - EVENTS_TRANSACTIONS_SUMMARY_*_BY_EVENT_NAME for transactions
 | |
|   */
 | |
|   uint m_event_name_index;
 | |
|   /** Instrument name. */
 | |
|   char m_name[PFS_MAX_INFO_NAME_LENGTH];
 | |
|   /** Length in bytes of @c m_name. */
 | |
|   uint m_name_length;
 | |
|   /** Timer associated with this class. */
 | |
|   enum_timer_name *m_timer;
 | |
| 
 | |
|   bool is_singleton() const
 | |
|   {
 | |
|     return m_flags & PSI_FLAG_GLOBAL;
 | |
|   }
 | |
| 
 | |
|   bool is_mutable() const
 | |
|   {
 | |
|     return m_flags & PSI_FLAG_MUTABLE;
 | |
|   }
 | |
| 
 | |
|   bool is_progress() const
 | |
|   {
 | |
|     assert(m_type == PFS_CLASS_STAGE);
 | |
|     return m_flags & PSI_FLAG_STAGE_PROGRESS;
 | |
|   }
 | |
| 
 | |
|   bool is_shared_exclusive() const
 | |
|   {
 | |
|     assert(m_type == PFS_CLASS_RWLOCK);
 | |
|     return m_flags & PSI_RWLOCK_FLAG_SX;
 | |
|   }
 | |
| 
 | |
|   static void set_enabled(PFS_instr_class *pfs, bool enabled);
 | |
|   static void set_timed(PFS_instr_class *pfs, bool timed);
 | |
| 
 | |
|   bool is_deferred() const
 | |
|   {
 | |
|     switch(m_type)
 | |
|     {
 | |
|       case PFS_CLASS_SOCKET:
 | |
|         return true;
 | |
|         break;
 | |
|       default:
 | |
|         return false;
 | |
|         break;
 | |
|     };
 | |
|   }
 | |
| };
 | |
| 
 | |
| struct PFS_mutex;
 | |
| 
 | |
| /** Instrumentation metadata for a MUTEX. */
 | |
| struct PFS_ALIGNED PFS_mutex_class : public PFS_instr_class
 | |
| {
 | |
|   /** Mutex usage statistics. */
 | |
|   PFS_mutex_stat m_mutex_stat;
 | |
|   /** Singleton instance. */
 | |
|   PFS_mutex *m_singleton;
 | |
| };
 | |
| 
 | |
| struct PFS_rwlock;
 | |
| 
 | |
| /** Instrumentation metadata for a RWLOCK. */
 | |
| struct PFS_ALIGNED PFS_rwlock_class : public PFS_instr_class
 | |
| {
 | |
|   /** Rwlock usage statistics. */
 | |
|   PFS_rwlock_stat m_rwlock_stat;
 | |
|   /** Singleton instance. */
 | |
|   PFS_rwlock *m_singleton;
 | |
| };
 | |
| 
 | |
| struct PFS_cond;
 | |
| 
 | |
| /** Instrumentation metadata for a COND. */
 | |
| struct PFS_ALIGNED PFS_cond_class : public PFS_instr_class
 | |
| {
 | |
|   /**
 | |
|     Condition usage statistics.
 | |
|     This statistic is not exposed in user visible tables yet.
 | |
|   */
 | |
|   PFS_cond_stat m_cond_stat;
 | |
|   /** Singleton instance. */
 | |
|   PFS_cond *m_singleton;
 | |
| };
 | |
| 
 | |
| /** Instrumentation metadata of a thread. */
 | |
| struct PFS_ALIGNED PFS_thread_class
 | |
| {
 | |
|   /** True if this thread instrument is enabled. */
 | |
|   bool m_enabled;
 | |
|   /** Singleton instance. */
 | |
|   PFS_thread *m_singleton;
 | |
|   /** Thread instrument name. */
 | |
|   char m_name[PFS_MAX_INFO_NAME_LENGTH];
 | |
|   /** Length in bytes of @c m_name. */
 | |
|   uint m_name_length;
 | |
|   /** Instrument flags. */
 | |
|   int m_flags;
 | |
|   bool is_system_thread() const { return m_flags & PSI_FLAG_THREAD_SYSTEM; }
 | |
| };
 | |
| 
 | |
| #define PFS_TABLESHARE_HASHKEY_SIZE (NAME_LEN + 1 + NAME_LEN + 1)
 | |
| 
 | |
| /** Key identifying a table share. */
 | |
| struct PFS_table_share_key
 | |
| {
 | |
|   /**
 | |
|     Hash search key.
 | |
|     This has to be a string for LF_HASH,
 | |
|     the format is "<enum_object_type><schema_name><0x00><object_name><0x00>"
 | |
|     @see create_table_def_key
 | |
|   */
 | |
|   char m_hash_key[PFS_TABLESHARE_HASHKEY_SIZE];
 | |
|   /** Length in bytes of @c m_hash_key. */
 | |
|   uint m_key_length;
 | |
| };
 | |
| 
 | |
| /** Table index or 'key' */
 | |
| struct PFS_table_key
 | |
| {
 | |
|   /** Index name */
 | |
|   char m_name[NAME_LEN];
 | |
|   /** Length in bytes of @c m_name. */
 | |
|   uint m_name_length;
 | |
| };
 | |
| 
 | |
| /** Index statistics of a table.*/
 | |
| struct PFS_table_share_index
 | |
| {
 | |
|   pfs_lock m_lock;
 | |
|   /** The index name */
 | |
|   PFS_table_key m_key;
 | |
|   /** The index stat */
 | |
|   PFS_table_io_stat m_stat;
 | |
|   /** Owner table share. To be used later. */
 | |
|   PFS_table_share* m_owner;
 | |
|   /** Container page. */
 | |
|   PFS_opaque_container_page *m_page;
 | |
| };
 | |
| 
 | |
| /** Lock statistics of a table.*/
 | |
| struct PFS_table_share_lock
 | |
| {
 | |
|   pfs_lock m_lock;
 | |
|   /** Lock stats. */
 | |
|   PFS_table_lock_stat m_stat;
 | |
|   /** Owner table share. To be used later. */
 | |
|   PFS_table_share* m_owner;
 | |
|   /** Container page. */
 | |
|   PFS_opaque_container_page *m_page;
 | |
| };
 | |
| 
 | |
| /** Instrumentation metadata for a table share. */
 | |
| struct PFS_ALIGNED PFS_table_share
 | |
| {
 | |
| public:
 | |
|   uint32 get_version()
 | |
|   { return m_lock.get_version(); }
 | |
| 
 | |
|   enum_object_type get_object_type()
 | |
|   {
 | |
|     return (enum_object_type) m_key.m_hash_key[0];
 | |
|   }
 | |
| 
 | |
|   void aggregate_io(void);
 | |
|   void aggregate_lock(void);
 | |
| 
 | |
|   void sum_io(PFS_single_stat *result, uint key_count);
 | |
|   void sum_lock(PFS_single_stat *result);
 | |
|   void sum(PFS_single_stat *result, uint key_count);
 | |
| 
 | |
|   inline void aggregate(void)
 | |
|   {
 | |
|     aggregate_io();
 | |
|     aggregate_lock();
 | |
|   }
 | |
| 
 | |
|   inline void init_refcount(void)
 | |
|   {
 | |
|     m_refcount.store(1);
 | |
|   }
 | |
| 
 | |
|   inline int get_refcount(void)
 | |
|   {
 | |
|     return m_refcount.load();
 | |
|   }
 | |
| 
 | |
|   inline void inc_refcount(void)
 | |
|   {
 | |
|     m_refcount.fetch_add(1);
 | |
|   }
 | |
| 
 | |
|   inline void dec_refcount(void)
 | |
|   {
 | |
|     m_refcount.fetch_sub(1);
 | |
|   }
 | |
| 
 | |
|   void refresh_setup_object_flags(PFS_thread *thread);
 | |
| 
 | |
|   /** Internal lock. */
 | |
|   pfs_lock m_lock;
 | |
|   /**
 | |
|     True if table instrumentation is enabled.
 | |
|     This flag is computed from the content of table setup_objects.
 | |
|   */
 | |
|   bool m_enabled;
 | |
|   /**
 | |
|     True if table instrumentation is timed.
 | |
|     This flag is computed from the content of table setup_objects.
 | |
|   */
 | |
|   bool m_timed;
 | |
| 
 | |
|   /** Search key. */
 | |
|   PFS_table_share_key m_key;
 | |
|   /** Schema name. */
 | |
|   const char *m_schema_name;
 | |
|   /** Length in bytes of @c m_schema_name. */
 | |
|   uint m_schema_name_length;
 | |
|   /** Table name. */
 | |
|   const char *m_table_name;
 | |
|   /** Length in bytes of @c m_table_name. */
 | |
|   uint m_table_name_length;
 | |
|   /** Number of indexes. */
 | |
|   uint m_key_count;
 | |
|   /** Container page. */
 | |
|   PFS_opaque_container_page *m_page;
 | |
| 
 | |
|   PFS_table_share_lock *find_lock_stat() const;
 | |
|   PFS_table_share_lock *find_or_create_lock_stat();
 | |
|   void destroy_lock_stat();
 | |
| 
 | |
|   PFS_table_share_index *find_index_stat(uint index) const;
 | |
|   PFS_table_share_index *find_or_create_index_stat(const TABLE_SHARE *server_share, uint index);
 | |
|   void destroy_index_stats();
 | |
| 
 | |
| private:
 | |
|   /** Number of opened table handles. */
 | |
|   std::atomic<int> m_refcount;
 | |
|   /** Table locks statistics. */
 | |
|   PFS_table_share_lock *m_race_lock_stat;
 | |
|   /** Table indexes' stats. */
 | |
|   PFS_table_share_index *m_race_index_stat[MAX_INDEXES + 1];
 | |
| };
 | |
| 
 | |
| /** Statistics for the IDLE instrument. */
 | |
| extern PFS_single_stat global_idle_stat;
 | |
| /** Statistics for dropped table io. */
 | |
| extern PFS_table_io_stat global_table_io_stat;
 | |
| /** Statistics for dropped table lock. */
 | |
| extern PFS_table_lock_stat global_table_lock_stat;
 | |
| /** Statistics for the METADATA instrument. */
 | |
| extern PFS_single_stat global_metadata_stat;
 | |
| /** Statistics for the transaction instrument. */
 | |
| extern PFS_transaction_stat global_transaction_stat;
 | |
| 
 | |
| inline uint sanitize_index_count(uint count)
 | |
| {
 | |
|   if (likely(count <= MAX_INDEXES))
 | |
|     return count;
 | |
|   return 0;
 | |
| }
 | |
| 
 | |
| #define GLOBAL_TABLE_IO_EVENT_INDEX 0
 | |
| #define GLOBAL_TABLE_LOCK_EVENT_INDEX 1
 | |
| #define GLOBAL_IDLE_EVENT_INDEX 2
 | |
| #define GLOBAL_METADATA_EVENT_INDEX 3
 | |
| /** Number of global wait events. */
 | |
| #define COUNT_GLOBAL_EVENT_INDEX 4
 | |
| 
 | |
| /** Transaction events are not wait events .*/
 | |
| #define GLOBAL_TRANSACTION_INDEX 0
 | |
| 
 | |
| /**
 | |
|   Instrument controlling all table io.
 | |
|   This instrument is used with table SETUP_OBJECTS.
 | |
| */
 | |
| extern PFS_instr_class global_table_io_class;
 | |
| 
 | |
| /**
 | |
|   Instrument controlling all table lock.
 | |
|   This instrument is used with table SETUP_OBJECTS.
 | |
| */
 | |
| extern PFS_instr_class global_table_lock_class;
 | |
| 
 | |
| /**
 | |
|   Instrument controlling all idle waits.
 | |
| */
 | |
| extern PFS_instr_class global_idle_class;
 | |
| 
 | |
| extern PFS_instr_class global_metadata_class;
 | |
| 
 | |
| struct PFS_file;
 | |
| 
 | |
| /** Instrumentation metadata for a file. */
 | |
| struct PFS_ALIGNED PFS_file_class : public PFS_instr_class
 | |
| {
 | |
|   /** File usage statistics. */
 | |
|   PFS_file_stat m_file_stat;
 | |
|   /** Singleton instance. */
 | |
|   PFS_file *m_singleton;
 | |
| };
 | |
| 
 | |
| /** Instrumentation metadata for a stage. */
 | |
| struct PFS_ALIGNED PFS_stage_class : public PFS_instr_class
 | |
| {
 | |
|   /**
 | |
|     Length of the 'stage/<component>/' prefix.
 | |
|     This is to extract 'foo' from 'stage/sql/foo'.
 | |
|   */
 | |
|   uint m_prefix_length;
 | |
|   /** Stage usage statistics. */
 | |
|   PFS_stage_stat m_stage_stat;
 | |
| };
 | |
| 
 | |
| /** Instrumentation metadata for a statement. */
 | |
| struct PFS_ALIGNED PFS_statement_class : public PFS_instr_class
 | |
| {
 | |
| };
 | |
| 
 | |
| /** Instrumentation metadata for a transaction. */
 | |
| struct PFS_ALIGNED PFS_transaction_class : public PFS_instr_class
 | |
| {
 | |
| };
 | |
| 
 | |
| extern PFS_transaction_class global_transaction_class;
 | |
| 
 | |
| struct PFS_socket;
 | |
| 
 | |
| /** Instrumentation metadata for a socket. */
 | |
| struct PFS_ALIGNED PFS_socket_class : public PFS_instr_class
 | |
| {
 | |
|   /** Socket usage statistics. */
 | |
|   PFS_socket_stat m_socket_stat;
 | |
|   /** Singleton instance. */
 | |
|   PFS_socket *m_singleton;
 | |
| };
 | |
| 
 | |
| /** Instrumentation metadata for a memory. */
 | |
| struct PFS_ALIGNED PFS_memory_class : public PFS_instr_class
 | |
| {
 | |
|   bool is_global() const
 | |
|   {
 | |
|     return m_flags & PSI_FLAG_GLOBAL;
 | |
|   }
 | |
| 
 | |
|   bool is_transferable() const
 | |
|   {
 | |
|     return m_flags & PSI_FLAG_TRANSFER;
 | |
|   }
 | |
| };
 | |
| 
 | |
| void init_event_name_sizing(const PFS_global_param *param);
 | |
| 
 | |
| void register_global_classes();
 | |
| 
 | |
| int init_sync_class(uint mutex_class_sizing,
 | |
|                     uint rwlock_class_sizing,
 | |
|                     uint cond_class_sizing);
 | |
| 
 | |
| void cleanup_sync_class();
 | |
| int init_thread_class(uint thread_class_sizing);
 | |
| void cleanup_thread_class();
 | |
| int init_table_share(uint table_share_sizing);
 | |
| void cleanup_table_share();
 | |
| 
 | |
| int init_table_share_lock_stat(uint table_stat_sizing);
 | |
| void cleanup_table_share_lock_stat();
 | |
| PFS_table_share_lock* create_table_share_lock_stat();
 | |
| void release_table_share_lock_stat(PFS_table_share_lock *pfs);
 | |
| 
 | |
| int init_table_share_index_stat(uint index_stat_sizing);
 | |
| void cleanup_table_share_index_stat();
 | |
| PFS_table_share_index* create_table_share_index_stat(const TABLE_SHARE *share, uint index);
 | |
| void release_table_share_index_stat(PFS_table_share_index *pfs);
 | |
| 
 | |
| int init_table_share_hash(const PFS_global_param *param);
 | |
| void cleanup_table_share_hash();
 | |
| int init_file_class(uint file_class_sizing);
 | |
| void cleanup_file_class();
 | |
| int init_stage_class(uint stage_class_sizing);
 | |
| void cleanup_stage_class();
 | |
| int init_statement_class(uint statement_class_sizing);
 | |
| void cleanup_statement_class();
 | |
| int init_socket_class(uint socket_class_sizing);
 | |
| void cleanup_socket_class();
 | |
| int init_memory_class(uint memory_class_sizing);
 | |
| void cleanup_memory_class();
 | |
| 
 | |
| PFS_sync_key register_mutex_class(const char *name, uint name_length,
 | |
|                                   int flags);
 | |
| 
 | |
| PFS_sync_key register_rwlock_class(const char *name, uint name_length,
 | |
|                                    int flags);
 | |
| 
 | |
| PFS_sync_key register_cond_class(const char *name, uint name_length,
 | |
|                                  int flags);
 | |
| 
 | |
| PFS_thread_key register_thread_class(const char *name, uint name_length,
 | |
|                                      int flags);
 | |
| 
 | |
| PFS_file_key register_file_class(const char *name, uint name_length,
 | |
|                                  int flags);
 | |
| 
 | |
| PFS_stage_key register_stage_class(const char *name,
 | |
|                                    uint prefix_length,
 | |
|                                    uint name_length,
 | |
|                                    int flags);
 | |
| 
 | |
| PFS_statement_key register_statement_class(const char *name, uint name_length,
 | |
|                                            int flags);
 | |
| 
 | |
| PFS_socket_key register_socket_class(const char *name, uint name_length,
 | |
|                                      int flags);
 | |
| 
 | |
| PFS_memory_key register_memory_class(const char *name, uint name_length,
 | |
|                                      int flags);
 | |
| 
 | |
| PFS_mutex_class *find_mutex_class(PSI_mutex_key key);
 | |
| PFS_mutex_class *sanitize_mutex_class(PFS_mutex_class *unsafe);
 | |
| PFS_rwlock_class *find_rwlock_class(PSI_rwlock_key key);
 | |
| PFS_rwlock_class *sanitize_rwlock_class(PFS_rwlock_class *unsafe);
 | |
| PFS_cond_class *find_cond_class(PSI_cond_key key);
 | |
| PFS_cond_class *sanitize_cond_class(PFS_cond_class *unsafe);
 | |
| PFS_thread_class *find_thread_class(PSI_thread_key key);
 | |
| PFS_thread_class *sanitize_thread_class(PFS_thread_class *unsafe);
 | |
| PFS_file_class *find_file_class(PSI_file_key key);
 | |
| PFS_file_class *sanitize_file_class(PFS_file_class *unsafe);
 | |
| PFS_stage_class *find_stage_class(PSI_stage_key key);
 | |
| PFS_stage_class *sanitize_stage_class(PFS_stage_class *unsafe);
 | |
| PFS_statement_class *find_statement_class(PSI_statement_key key);
 | |
| PFS_statement_class *sanitize_statement_class(PFS_statement_class *unsafe);
 | |
| PFS_instr_class *find_table_class(uint index);
 | |
| PFS_instr_class *sanitize_table_class(PFS_instr_class *unsafe);
 | |
| PFS_socket_class *find_socket_class(PSI_socket_key key);
 | |
| PFS_socket_class *sanitize_socket_class(PFS_socket_class *unsafe);
 | |
| PFS_memory_class *find_memory_class(PSI_memory_key key);
 | |
| PFS_memory_class *sanitize_memory_class(PFS_memory_class *unsafe);
 | |
| PFS_instr_class *find_idle_class(uint index);
 | |
| PFS_instr_class *sanitize_idle_class(PFS_instr_class *unsafe);
 | |
| PFS_instr_class *find_metadata_class(uint index);
 | |
| PFS_instr_class *sanitize_metadata_class(PFS_instr_class *unsafe);
 | |
| PFS_transaction_class *find_transaction_class(uint index);
 | |
| PFS_transaction_class *sanitize_transaction_class(PFS_transaction_class *unsafe);
 | |
| 
 | |
| PFS_table_share *find_or_create_table_share(PFS_thread *thread,
 | |
|                                             bool temporary,
 | |
|                                             const TABLE_SHARE *share);
 | |
| void release_table_share(PFS_table_share *pfs);
 | |
| void drop_table_share(PFS_thread *thread,
 | |
|                       bool temporary,
 | |
|                       const char *schema_name, uint schema_name_length,
 | |
|                       const char *table_name, uint table_name_length);
 | |
| 
 | |
| PFS_table_share *sanitize_table_share(PFS_table_share *unsafe);
 | |
| 
 | |
| extern ulong mutex_class_max;
 | |
| extern ulong mutex_class_lost;
 | |
| extern ulong rwlock_class_max;
 | |
| extern ulong rwlock_class_lost;
 | |
| extern ulong cond_class_max;
 | |
| extern ulong cond_class_lost;
 | |
| extern ulong thread_class_max;
 | |
| extern ulong thread_class_lost;
 | |
| extern ulong file_class_max;
 | |
| extern ulong file_class_lost;
 | |
| extern ulong stage_class_max;
 | |
| extern ulong stage_class_lost;
 | |
| extern ulong statement_class_max;
 | |
| extern ulong statement_class_lost;
 | |
| extern ulong transaction_class_max;
 | |
| extern ulong socket_class_max;
 | |
| extern ulong socket_class_lost;
 | |
| extern ulong memory_class_max;
 | |
| extern ulong memory_class_lost;
 | |
| 
 | |
| /* Exposing the data directly, for iterators. */
 | |
| 
 | |
| extern PFS_mutex_class *mutex_class_array;
 | |
| extern PFS_rwlock_class *rwlock_class_array;
 | |
| extern PFS_cond_class *cond_class_array;
 | |
| extern PFS_file_class *file_class_array;
 | |
| 
 | |
| void reset_events_waits_by_class();
 | |
| void reset_file_class_io();
 | |
| void reset_socket_class_io();
 | |
| 
 | |
| /** Update derived flags for all table shares. */
 | |
| void update_table_share_derived_flags(PFS_thread *thread);
 | |
| 
 | |
| /** Update derived flags for all stored procedure shares. */
 | |
| void update_program_share_derived_flags(PFS_thread *thread);
 | |
| 
 | |
| extern LF_HASH table_share_hash;
 | |
| 
 | |
| /** @} */
 | |
| #endif
 | |
| 
 |