mirror of
https://github.com/MariaDB/server.git
synced 2025-07-29 05:21:33 +03:00
MDEV-5345 - Deadlock between mysql_change_user(), SHOW VARIABLES and
INSTALL PLUGIN There was mixed lock order between LOCK_plugin, LOCK_global_system_variables and LOCK_system_variables_hash. This patch ensures that write-lock on LOCK_system_variables_hash doesn't intersect with LOCK_plugin. Fixed by moving initialization/deinitialization of plugin options from plugin_add()/plugin_del() to plugin_initialize()/plugin_deinitalize(). So that plugin options are handled without protection of LOCK_plugin.
This commit is contained in:
22
mysql-test/r/plugin_vars.result
Normal file
22
mysql-test/r/plugin_vars.result
Normal file
@ -0,0 +1,22 @@
|
||||
#
|
||||
# MDEV-5345 - Deadlock between mysql_change_user(), SHOW VARIABLES and
|
||||
# INSTALL PLUGIN
|
||||
#
|
||||
CREATE PROCEDURE p_install(x INT)
|
||||
BEGIN
|
||||
DECLARE CONTINUE HANDLER FOR 1126 BEGIN END;
|
||||
WHILE x DO
|
||||
SET x= x - 1;
|
||||
INSTALL PLUGIN no_such_plugin SONAME 'no_such_object';
|
||||
END WHILE;
|
||||
END|
|
||||
CREATE PROCEDURE p_show_vars(x INT)
|
||||
WHILE x DO
|
||||
SET x= x - 1;
|
||||
SHOW VARIABLES;
|
||||
END WHILE|
|
||||
CALL p_install(100);
|
||||
CALL p_show_vars(100);
|
||||
USE test;
|
||||
DROP PROCEDURE p_install;
|
||||
DROP PROCEDURE p_show_vars;
|
Reference in New Issue
Block a user