Commit d6a1f9f1 authored by Marko Mäkelä's avatar Marko Mäkelä

MDEV-11630 Call mutex_free() before freeing the mutex list

fil_space_crypt_cleanup(): Call mutex_free() to pair with
fil_space_crypt_init().

fil_space_destroy_crypt_data(): Call mutex_free() to pair with
fil_space_create_crypt_data() and fil_space_read_crypt_data().

fil_crypt_threads_cleanup(): Call mutex_free() to pair with
fil_crypt_threads_init().

fil_space_free_low(): Invoke fil_space_destroy_crypt_data().

fil_close(): Invoke fil_space_crypt_cleanup(), just like
fil_init() invoked fil_space_crypt_init().

Datafile::shutdown(): Set m_crypt_info=NULL without dereferencing
the pointer. The object will be freed along with the fil_space_t
in fil_space_free_low().
Remove some unnecessary conditions (ut_free(NULL) is OK).

srv_shutdown_all_bg_threads(): Shut down the encryption threads
by calling fil_crypt_threads_end().

srv_shutdown_bg_undo_sources(): Do not prematurely call
fil_crypt_threads_end(). Many pages can still be written by
change buffer merge, rollback of incomplete transactions, and
purge, especially in slow shutdown (innodb_fast_shutdown=0).

innobase_shutdown_for_mysql(): Call fil_crypt_threads_cleanup()
also when innodb_read_only=1, because the threads will have been
created also in that case.

sync_check_close(): Re-enable the invocation of sync_latch_meta_destroy()
to free the mutex list.
parent 0c3791ca
...@@ -138,6 +138,8 @@ fil_space_crypt_cleanup() ...@@ -138,6 +138,8 @@ fil_space_crypt_cleanup()
/*=====================*/ /*=====================*/
{ {
os_event_destroy(fil_crypt_throttle_sleep_event); os_event_destroy(fil_crypt_throttle_sleep_event);
mutex_free(&fil_crypt_key_mutex);
mutex_free(&crypt_stat_mutex);
} }
/****************************************************************** /******************************************************************
...@@ -335,15 +337,9 @@ fil_space_destroy_crypt_data( ...@@ -335,15 +337,9 @@ fil_space_destroy_crypt_data(
and make it unawailable, this does not fully and make it unawailable, this does not fully
avoid the race between drop table and crypt thread */ avoid the race between drop table and crypt thread */
mutex_enter(&fil_crypt_threads_mutex); mutex_enter(&fil_crypt_threads_mutex);
mutex_enter(&(*crypt_data)->mutex); mutex_free(&(*crypt_data)->mutex);
(*crypt_data)->inited = false;
mutex_exit(&(*crypt_data)->mutex);
/* JAN: TODO:
mutex_free(& (*crypt_data)->mutex);
memset(*crypt_data, 0, sizeof(fil_space_crypt_t));
free(*crypt_data); free(*crypt_data);
(*crypt_data) = NULL; *crypt_data = NULL;
*/
mutex_exit(&fil_crypt_threads_mutex); mutex_exit(&fil_crypt_threads_mutex);
} }
} }
...@@ -2468,6 +2464,7 @@ fil_crypt_threads_cleanup() ...@@ -2468,6 +2464,7 @@ fil_crypt_threads_cleanup()
{ {
os_event_destroy(fil_crypt_event); os_event_destroy(fil_crypt_event);
os_event_destroy(fil_crypt_threads_event); os_event_destroy(fil_crypt_threads_event);
mutex_free(&fil_crypt_threads_mutex);
fil_crypt_threads_inited = false; fil_crypt_threads_inited = false;
} }
......
...@@ -1199,6 +1199,7 @@ fil_space_free_low( ...@@ -1199,6 +1199,7 @@ fil_space_free_low(
ut_ad(space->size == 0); ut_ad(space->size == 0);
rw_lock_free(&space->latch); rw_lock_free(&space->latch);
fil_space_destroy_crypt_data(&space->crypt_data);
ut_free(space->name); ut_free(space->name);
ut_free(space); ut_free(space);
...@@ -6226,6 +6227,8 @@ fil_close(void) ...@@ -6226,6 +6227,8 @@ fil_close(void)
ut_free(fil_system); ut_free(fil_system);
fil_system = NULL; fil_system = NULL;
fil_space_crypt_cleanup();
} }
} }
......
...@@ -63,22 +63,17 @@ Datafile::shutdown() ...@@ -63,22 +63,17 @@ Datafile::shutdown()
ut_free(m_name); ut_free(m_name);
m_name = NULL; m_name = NULL;
free_filepath();
if (m_encryption_key != NULL) {
ut_free(m_encryption_key); ut_free(m_encryption_key);
m_encryption_key = NULL; m_encryption_key = NULL;
}
if (m_crypt_info) { /* The fil_space_t::crypt_data was freed in
fil_space_destroy_crypt_data(&m_crypt_info); fil_space_free_low(). Invalidate our redundant pointer. */
} m_crypt_info = NULL;
if (m_encryption_iv != NULL) {
ut_free(m_encryption_iv); ut_free(m_encryption_iv);
m_encryption_iv = NULL; m_encryption_iv = NULL;
}
free_filepath();
free_first_page(); free_first_page();
} }
......
...@@ -97,8 +97,6 @@ extern const char general_space_name[]; ...@@ -97,8 +97,6 @@ extern const char general_space_name[];
struct trx_t; struct trx_t;
class page_id_t; class page_id_t;
class truncate_t; class truncate_t;
struct fil_node_t;
struct fil_space_t;
struct btr_create_t; struct btr_create_t;
/* structure containing encryption specification */ /* structure containing encryption specification */
......
...@@ -1226,6 +1226,7 @@ srv_shutdown_all_bg_threads() ...@@ -1226,6 +1226,7 @@ srv_shutdown_all_bg_threads()
ulint i; ulint i;
srv_shutdown_state = SRV_SHUTDOWN_EXIT_THREADS; srv_shutdown_state = SRV_SHUTDOWN_EXIT_THREADS;
fil_crypt_threads_end();
if (!srv_start_state) { if (!srv_start_state) {
return; return;
...@@ -2769,9 +2770,6 @@ srv_shutdown_bg_undo_sources(void) ...@@ -2769,9 +2770,6 @@ srv_shutdown_bg_undo_sources(void)
{ {
fts_optimize_shutdown(); fts_optimize_shutdown();
dict_stats_shutdown(); dict_stats_shutdown();
/* Shutdown key rotation threads */
fil_crypt_threads_end();
} }
...@@ -2839,9 +2837,7 @@ innobase_shutdown_for_mysql(void) ...@@ -2839,9 +2837,7 @@ innobase_shutdown_for_mysql(void)
} }
} }
if (!srv_read_only_mode) {
fil_crypt_threads_cleanup(); fil_crypt_threads_cleanup();
}
/* Cleanup data for datafile scrubbing */ /* Cleanup data for datafile scrubbing */
btr_scrub_cleanup(); btr_scrub_cleanup();
......
...@@ -1582,7 +1582,6 @@ sync_latch_meta_init() ...@@ -1582,7 +1582,6 @@ sync_latch_meta_init()
} }
/** Destroy the latch meta data */ /** Destroy the latch meta data */
#ifdef JAN_DISABLED_FOR_NOW_AS_THIS_CAUSES_CRASH
static static
void void
sync_latch_meta_destroy() sync_latch_meta_destroy()
...@@ -1596,7 +1595,6 @@ sync_latch_meta_destroy() ...@@ -1596,7 +1595,6 @@ sync_latch_meta_destroy()
latch_meta.clear(); latch_meta.clear();
} }
#endif
/** Track mutex file creation name and line number. This is to avoid storing /** Track mutex file creation name and line number. This is to avoid storing
{ const char* name; uint16_t line; } in every instance. This results in the { const char* name; uint16_t line; } in every instance. This results in the
...@@ -1810,8 +1808,6 @@ sync_check_close() ...@@ -1810,8 +1808,6 @@ sync_check_close()
create_tracker = NULL; create_tracker = NULL;
#ifdef JAN_DISABLED_FOR_NOW_AS_THIS_CAUSES_CRASH
sync_latch_meta_destroy(); sync_latch_meta_destroy();
#endif
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment