Commit eb00a122 authored by Rich Prohaska's avatar Rich Prohaska

#250 reset thd proc info in end_bulk_insert to fix invalid proc info pointer...

#250 reset thd proc info in end_bulk_insert to fix invalid proc info pointer inside of a deleted ha_tokudb object
parent f16b3122
...@@ -3382,6 +3382,7 @@ cleanup: ...@@ -3382,6 +3382,7 @@ cleanup:
} }
} }
trx->stmt_progress.using_loader = false; trx->stmt_progress.using_loader = false;
thd_proc_info(thd, 0);
TOKUDB_HANDLER_DBUG_RETURN(error ? error : loader_error); TOKUDB_HANDLER_DBUG_RETURN(error ? error : loader_error);
} }
......
...@@ -210,11 +210,10 @@ static int hot_poll_fun(void *extra, float progress) { ...@@ -210,11 +210,10 @@ static int hot_poll_fun(void *extra, float progress) {
return 0; return 0;
} }
volatile int ha_tokudb_optimize_wait;
// flatten all DB's in this table, to do so, peform hot optimize on each db // flatten all DB's in this table, to do so, peform hot optimize on each db
int ha_tokudb::do_optimize(THD *thd) { int ha_tokudb::do_optimize(THD *thd) {
TOKUDB_HANDLER_DBUG_ENTER("%s", share->table_name); TOKUDB_HANDLER_DBUG_ENTER("%s", share->table_name);
const char *orig_proc_info = tokudb_thd_get_proc_info(thd);
int error; int error;
uint curr_num_DBs = table->s->keys + tokudb_test(hidden_primary_key); uint curr_num_DBs = table->s->keys + tokudb_test(hidden_primary_key);
...@@ -247,23 +246,21 @@ int ha_tokudb::do_optimize(THD *thd) { ...@@ -247,23 +246,21 @@ int ha_tokudb::do_optimize(THD *thd) {
error = 0; error = 0;
cleanup: cleanup:
while (ha_tokudb_optimize_wait) sleep(1);
#ifdef HA_TOKUDB_HAS_THD_PROGRESS #ifdef HA_TOKUDB_HAS_THD_PROGRESS
thd_progress_end(thd); thd_progress_end(thd);
#endif #endif
thd_proc_info(thd, orig_proc_info);
TOKUDB_HANDLER_DBUG_RETURN(error); TOKUDB_HANDLER_DBUG_RETURN(error);
} }
int ha_tokudb::optimize(THD *thd, HA_CHECK_OPT *check_opt) { int ha_tokudb::optimize(THD *thd, HA_CHECK_OPT *check_opt) {
TOKUDB_HANDLER_DBUG_ENTER("%s", share->table_name); TOKUDB_HANDLER_DBUG_ENTER("%s", share->table_name);
const char *orig_proc_info = tokudb_thd_get_proc_info(thd);
int error; int error;
#if TOKU_OPTIMIZE_WITH_RECREATE #if TOKU_OPTIMIZE_WITH_RECREATE
error = HA_ADMIN_TRY_ALTER; error = HA_ADMIN_TRY_ALTER;
#else #else
error = do_optimize(thd); error = do_optimize(thd);
#endif #endif
thd_proc_info(thd, orig_proc_info);
TOKUDB_HANDLER_DBUG_RETURN(error); TOKUDB_HANDLER_DBUG_RETURN(error);
} }
......
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