MySQL 9.0.0
Source Code Documentation
psi_cond_service.h
Go to the documentation of this file.
1/* Copyright (c) 2017, 2024, Oracle and/or its affiliates.
2
3This program is free software; you can redistribute it and/or modify
4it under the terms of the GNU General Public License, version 2.0,
5as published by the Free Software Foundation.
6
7This program is designed to work with certain software (including
8but not limited to OpenSSL) that is licensed under separate terms,
9as designated in a particular file or component or in included license
10documentation. The authors of MySQL hereby grant you an additional
11permission to link the program and your derivative works with the
12separately licensed software that they have either included with
13the program or referenced in the documentation.
14
15This program is distributed in the hope that it will be useful,
16but WITHOUT ANY WARRANTY; without even the implied warranty of
17MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18GNU General Public License, version 2.0, for more details.
19
20You should have received a copy of the GNU General Public License
21along with this program; if not, write to the Free Software
22Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
23
24#ifndef COMPONENTS_SERVICES_PSI_COND_SERVICE_H
25#define COMPONENTS_SERVICES_PSI_COND_SERVICE_H
26
29
31/** @sa register_cond_v1_t. */
32register_cond_v1_t register_cond;
33/** @sa init_cond_v1_t. */
35/** @sa destroy_cond_v1_t. */
37/** @sa signal_cond_v1_t. */
38signal_cond_v1_t signal_cond;
39/** @sa broadcast_cond_v1_t. */
40broadcast_cond_v1_t broadcast_cond;
41/** @sa start_cond_wait_v1_t. */
42start_cond_wait_v1_t start_cond_wait;
43/** @sa end_cond_wait_v1_t. */
44end_cond_wait_v1_t end_cond_wait;
46
47#endif /* COMPONENTS_SERVICES_PSI_COND_SERVICE_H */
void destroy_cond(PFS_cond *pfs)
Destroy instrumentation for a condition instance.
Definition: pfs_instr.cc:473
struct PSI_cond *(* init_cond_v1_t)(PSI_cond_key key, const void *identity)
Cond instrumentation initialisation API.
Definition: psi_cond_bits.h:153
void(* register_cond_v1_t)(const char *category, struct PSI_cond_info_v1 *info, int count)
Cond registration API.
Definition: psi_cond_bits.h:144
void(* broadcast_cond_v1_t)(struct PSI_cond *cond)
Record a condition instrumentation broadcast event.
Definition: psi_cond_bits.h:172
void(* destroy_cond_v1_t)(struct PSI_cond *cond)
Cond instrumentation destruction API.
Definition: psi_cond_bits.h:160
struct PSI_cond_locker *(* start_cond_wait_v1_t)(struct PSI_cond_locker_state_v1 *state, struct PSI_cond *cond, struct PSI_mutex *mutex, enum PSI_cond_operation op, const char *src_file, unsigned int src_line)
Record a condition instrumentation wait start event.
Definition: psi_cond_bits.h:184
void(* signal_cond_v1_t)(struct PSI_cond *cond)
Record a condition instrumentation signal event.
Definition: psi_cond_bits.h:166
void(* end_cond_wait_v1_t)(struct PSI_cond_locker *locker, int rc)
Record a condition instrumentation wait end event.
Definition: psi_cond_bits.h:194
Performance schema instrumentation interface.
#define END_SERVICE_DEFINITION(name)
A macro to end the last Service definition started with the BEGIN_SERVICE_DEFINITION macro.
Definition: service.h:91
#define BEGIN_SERVICE_DEFINITION(name)
Declares a new Service.
Definition: service.h:86