From bbae2d398f866b00f7e8ad71984884ff3375df52 Mon Sep 17 00:00:00 2001 From: Andrei Elkin Date: Wed, 29 Sep 2021 19:19:38 +0300 Subject: MDEV-26712 row events never reset thd->mem_root but must do that at the end of the statement. A provide template patch is elaborated also to match to the upstream fixes of the very same bug. --- sql/log_event.cc | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/sql/log_event.cc b/sql/log_event.cc index 04577be4f6f..9108b57fec1 100644 --- a/sql/log_event.cc +++ b/sql/log_event.cc @@ -11208,12 +11208,17 @@ int Rows_log_event::do_apply_event(rpl_group_info *rgi) } #endif /* WITH_WSREP && HAVE_QUERY_CACHE */ - if (get_flags(STMT_END_F) && (error= rows_event_stmt_cleanup(rgi, thd))) - slave_rows_error_report(ERROR_LEVEL, - thd->is_error() ? 0 : error, - rgi, thd, table, - get_type_str(), - RPL_LOG_NAME, (ulong) log_pos); + if (get_flags(STMT_END_F)) + { + if ((error= rows_event_stmt_cleanup(rgi, thd))) + slave_rows_error_report(ERROR_LEVEL, + thd->is_error() ? 0 : error, + rgi, thd, table, + get_type_str(), + RPL_LOG_NAME, (ulong) log_pos); + if (thd->slave_thread) + free_root(thd->mem_root, MYF(MY_KEEP_PREALLOC)); + } DBUG_RETURN(error); err: -- cgit v1.2.1