summaryrefslogtreecommitdiff
path: root/cmake/install_macros.cmake
diff options
context:
space:
mode:
authorJan Lindström <jan.lindstrom@mariadb.com>2020-12-17 14:20:23 +0200
committerJan Lindström <jan.lindstrom@mariadb.com>2021-01-08 17:11:54 +0200
commit775fccea0c24b529bb2ec6888e34e7fae2ba25dd (patch)
tree77dc8f587dbc2f7df986491181427fb30e8dfa0c /cmake/install_macros.cmake
parent18254c18d9c321835fbac1866be9ecbf4a8fe9c1 (diff)
downloadmariadb-git-775fccea0c24b529bb2ec6888e34e7fae2ba25dd.tar.gz
MDEV-23536 : Race condition between KILL and transaction commit
A race condition may occur between the execution of transaction commit, and an execution of a KILL statement that would attempt to abort that transaction. MDEV-17092 worked around this race condition by modifying InnoDB code. After that issue was closed, Sergey Vojtovich pointed out that this race condition would better be fixed above the storage engine layer: If you look carefully into the above, you can conclude that thd->free_connection() can be called concurrently with KILL/thd->awake(). Which is the bug. And it is partially fixed in THD::~THD(), that is destructor waits for KILL completion: Fix: Add necessary mutex operations to THD::free_connection() and move WSREP specific code also there. This ensures that no one is using THD while we do free_connection(). These mutexes will also ensures that there can't be concurrent KILL/THD::awake(). innobase_kill_query We can now remove usage of trx_sys_mutex introduced on MDEV-17092. trx_t::free() Poison trx->state and trx->mysql_thd This patch is validated with an RQG run similar to the one that reproduced MDEV-17092.
Diffstat (limited to 'cmake/install_macros.cmake')
0 files changed, 0 insertions, 0 deletions