From e6f452c7cd438ebd7f1068f4c508b49e2d916094 Mon Sep 17 00:00:00 2001 From: marko <> Date: Fri, 19 Oct 2007 10:30:34 +0000 Subject: [PATCH] branches/zip: srv_suspend_mysql_thread(): Allow the transaction to hold an X-latch to the data dictionary, to avoid an assertion failure when a lock wait occurs in row_merge_lock_table(). --- srv/srv0srv.c | 23 ++++++++++++++++------- 1 file changed, 16 insertions(+), 7 deletions(-) diff --git a/srv/srv0srv.c b/srv/srv0srv.c index fd3189b32dc..3c214e70e94 100644 --- a/srv/srv0srv.c +++ b/srv/srv0srv.c @@ -1387,7 +1387,7 @@ srv_suspend_mysql_thread( os_event_t event; double wait_time; trx_t* trx; - ibool had_dict_lock = FALSE; + ulint had_dict_lock; ibool was_declared_inside_innodb = FALSE; ib_longlong start_time = 0; ib_longlong finish_time; @@ -1459,12 +1459,17 @@ srv_suspend_mysql_thread( srv_conc_force_exit_innodb(trx); } - /* Release possible foreign key check latch */ - if (trx->dict_operation_lock_mode == RW_S_LATCH) { - - had_dict_lock = TRUE; + had_dict_lock = trx->dict_operation_lock_mode; + switch (had_dict_lock) { + case RW_S_LATCH: + /* Release foreign key check latch */ row_mysql_unfreeze_data_dictionary(trx); + break; + case RW_X_LATCH: + /* Release fast index creation latch */ + row_mysql_unlock_data_dictionary(trx); + break; } ut_a(trx->dict_operation_lock_mode == 0); @@ -1473,9 +1478,13 @@ srv_suspend_mysql_thread( os_event_wait(event); - if (had_dict_lock) { - + switch (had_dict_lock) { + case RW_S_LATCH: row_mysql_freeze_data_dictionary(trx); + break; + case RW_X_LATCH: + row_mysql_lock_data_dictionary(trx); + break; } if (was_declared_inside_innodb) {