/* Copyright (c) 2014, 2022, 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, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ #ifndef MYSQL_SERVICE_TRANSACTION_WRITE_SET_INCLUDED /** @file include/mysql/service_rpl_transaction_write_set.h This service provides a function for plugins to get the write set of a given transaction. SYNOPSIS get_transaction_write_set() This service is used to fetch the write_set extracted for the currently executing transaction by passing the thread_id as an input parameter for the method. @param [in] - thread_id - It is the thread identifier of the currently executing thread. In the current implementation it is being called during RUN_HOOK macro, on which we know that thread is on plugin context. Cleanup : The service caller must take of the memory allocated during the service call to prevent memory leaks. */ #ifndef MYSQL_ABI_CHECK #include #endif #ifdef __cplusplus extern "C" { #endif /** This structure is used to keep the list of the hash values of the records changed in the transaction. */ struct st_trans_write_set { unsigned int m_flags; // reserved unsigned long write_set_size; // Size of the PKE set of the transaction. unsigned long long* write_set; // A pointer to the PKE set. }; typedef struct st_trans_write_set Transaction_write_set; extern struct transaction_write_set_service_st { Transaction_write_set* (*get_transaction_write_set)(unsigned long m_thread_id); void (*require_full_write_set)(int requires_ws); void (*set_write_set_memory_size_limit)(long long size_limit); void (*update_write_set_memory_size_limit)(long long size_limit); } *transaction_write_set_service; #ifdef MYSQL_DYNAMIC_PLUGIN #define get_transaction_write_set(m_thread_id) \ (transaction_write_set_service->get_transaction_write_set((m_thread_id))) #define require_full_write_set(requires_ws) \ transaction_write_set_service->require_full_write_set(requires_ws) #define set_write_set_memory_size_limit(size_limit) \ transaction_write_set_service->set_write_set_memory_size_limit(size_limit) #define update_write_set_memory_size_limit(size_limit) \ transaction_write_set_service->update_write_set_memory_size_limit(size_limit) #else Transaction_write_set* get_transaction_write_set(unsigned long m_thread_id); void require_full_write_set(int requires_ws); void set_write_set_memory_size_limit(long long size_limit); void update_write_set_memory_size_limit(long long size_limit); #endif #ifdef __cplusplus } #endif #define MYSQL_SERVICE_TRANSACTION_WRITE_SET_INCLUDED #endif