Commit 9fb47e36 authored by Zardosht Kasheff's avatar Zardosht Kasheff Committed by Yoni Fogel

[t:3518], fix bug on mainline

git-svn-id: file:///svn/mysql/tokudb-engine/tokudb-engine@34462 c7de825b-a66e-492c-adef-691d508d4ae1
parent 3a22f7f1
...@@ -985,16 +985,10 @@ static int rename_table_in_metadata(const char *from, const char *to, DB_TXN* tx ...@@ -985,16 +985,10 @@ static int rename_table_in_metadata(const char *from, const char *to, DB_TXN* tx
} }
static int check_table_in_metadata(const char *name, bool* table_found) { static int check_table_in_metadata(const char *name, bool* table_found, DB_TXN* txn) {
int error = 0; int error = 0;
DBT key; DBT key;
DB_TXN* txn = NULL;
pthread_mutex_lock(&tokudb_meta_mutex); pthread_mutex_lock(&tokudb_meta_mutex);
error = db_env->txn_begin(db_env, 0, &txn, 0);
if (error) {
goto cleanup;
}
bzero((void *)&key, sizeof(key)); bzero((void *)&key, sizeof(key));
key.data = (void *)name; key.data = (void *)name;
key.size = strlen(name) + 1; key.size = strlen(name) + 1;
...@@ -1016,10 +1010,6 @@ static int check_table_in_metadata(const char *name, bool* table_found) { ...@@ -1016,10 +1010,6 @@ static int check_table_in_metadata(const char *name, bool* table_found) {
error = 0; error = 0;
} }
cleanup:
if (txn) {
commit_txn(txn, 0);
}
pthread_mutex_unlock(&tokudb_meta_mutex); pthread_mutex_unlock(&tokudb_meta_mutex);
return error; return error;
} }
...@@ -1609,10 +1599,23 @@ int ha_tokudb::initialize_share( ...@@ -1609,10 +1599,23 @@ int ha_tokudb::initialize_share(
int error = 0; int error = 0;
u_int64_t num_rows = 0; u_int64_t num_rows = 0;
bool table_exists; bool table_exists;
DB_TXN* txn = NULL;
bool do_commit = false;
tokudb_trx_data *trx = NULL;
trx = (tokudb_trx_data *) thd_data_get(ha_thd(), tokudb_hton->slot);
if (trx && trx->sub_sp_level) {
txn = trx->sub_sp_level;
}
else {
do_commit = true;
error = db_env->txn_begin(db_env, 0, &txn, 0);
if (error) { goto exit; }
}
DBUG_PRINT("info", ("share->use_count %u", share->use_count)); DBUG_PRINT("info", ("share->use_count %u", share->use_count));
table_exists = true; table_exists = true;
error = check_table_in_metadata(name, &table_exists); error = check_table_in_metadata(name, &table_exists, txn);
if (error) { if (error) {
goto exit; goto exit;
...@@ -1623,7 +1626,7 @@ int ha_tokudb::initialize_share( ...@@ -1623,7 +1626,7 @@ int ha_tokudb::initialize_share(
goto exit; goto exit;
} }
error = get_status(); error = get_status(txn);
if (error) { if (error) {
goto exit; goto exit;
} }
...@@ -1637,7 +1640,7 @@ int ha_tokudb::initialize_share( ...@@ -1637,7 +1640,7 @@ int ha_tokudb::initialize_share(
// only for tables that are not partitioned // only for tables that are not partitioned
// //
if (table->part_info == NULL) { if (table->part_info == NULL) {
error = verify_frm_data(table->s->path.str); error = verify_frm_data(table->s->path.str, txn);
if (error) { if (error) {
goto exit; goto exit;
} }
...@@ -1651,7 +1654,7 @@ int ha_tokudb::initialize_share( ...@@ -1651,7 +1654,7 @@ int ha_tokudb::initialize_share(
); );
if (error) { goto exit; } if (error) { goto exit; }
error = open_main_dictionary(name, mode == O_RDONLY, NULL); error = open_main_dictionary(name, mode == O_RDONLY, txn);
if (error) { goto exit; } if (error) { goto exit; }
share->has_unique_keys = false; share->has_unique_keys = false;
...@@ -1669,7 +1672,7 @@ int ha_tokudb::initialize_share( ...@@ -1669,7 +1672,7 @@ int ha_tokudb::initialize_share(
&table_share->key_info[i], &table_share->key_info[i],
name, name,
mode == O_RDONLY, mode == O_RDONLY,
NULL txn
); );
if (error) { if (error) {
goto exit; goto exit;
...@@ -1697,7 +1700,7 @@ int ha_tokudb::initialize_share( ...@@ -1697,7 +1700,7 @@ int ha_tokudb::initialize_share(
} }
share->ref_length = ref_length; share->ref_length = ref_length;
error = estimate_num_rows(share->file,&num_rows, NULL); error = estimate_num_rows(share->file,&num_rows, txn);
// //
// estimate_num_rows should not fail under normal conditions // estimate_num_rows should not fail under normal conditions
// //
...@@ -1726,6 +1729,9 @@ int ha_tokudb::initialize_share( ...@@ -1726,6 +1729,9 @@ int ha_tokudb::initialize_share(
error = 0; error = 0;
exit: exit:
if (do_commit && txn) {
commit_txn(txn,0);
}
return error; return error;
} }
...@@ -2055,18 +2061,14 @@ smart_dbt_callback_verify_frm (DBT const *key, DBT const *row, void *context) { ...@@ -2055,18 +2061,14 @@ smart_dbt_callback_verify_frm (DBT const *key, DBT const *row, void *context) {
return 0; return 0;
} }
int ha_tokudb::verify_frm_data(const char* frm_name) { int ha_tokudb::verify_frm_data(const char* frm_name, DB_TXN* txn) {
uchar* mysql_frm_data = NULL; uchar* mysql_frm_data = NULL;
size_t mysql_frm_len = 0; size_t mysql_frm_len = 0;
DBT key, stored_frm; DBT key, stored_frm;
int error = 0; int error = 0;
DB_TXN* txn = NULL;
HA_METADATA_KEY curr_key = hatoku_frm_data; HA_METADATA_KEY curr_key = hatoku_frm_data;
TOKUDB_DBUG_ENTER("ha_tokudb::verify_frm_data %s", frm_name); TOKUDB_DBUG_ENTER("ha_tokudb::verify_frm_data %s", frm_name);
error = db_env->txn_begin(db_env, 0, &txn, 0);
if (error) { goto cleanup; }
bzero(&key, sizeof(key)); bzero(&key, sizeof(key));
bzero(&stored_frm, sizeof(&stored_frm)); bzero(&stored_frm, sizeof(&stored_frm));
// get the frm data from MySQL // get the frm data from MySQL
...@@ -2105,9 +2107,6 @@ int ha_tokudb::verify_frm_data(const char* frm_name) { ...@@ -2105,9 +2107,6 @@ int ha_tokudb::verify_frm_data(const char* frm_name) {
error = 0; error = 0;
cleanup: cleanup:
if (txn) {
commit_txn(txn, 0);
}
my_free(mysql_frm_data, MYF(MY_ALLOW_ZERO_PTR)); my_free(mysql_frm_data, MYF(MY_ALLOW_ZERO_PTR));
my_free(stored_frm.data, MYF(MY_ALLOW_ZERO_PTR)); my_free(stored_frm.data, MYF(MY_ALLOW_ZERO_PTR));
TOKUDB_DBUG_RETURN(error); TOKUDB_DBUG_RETURN(error);
...@@ -2926,12 +2925,12 @@ void ha_tokudb::init_hidden_prim_key_info() { ...@@ -2926,12 +2925,12 @@ void ha_tokudb::init_hidden_prim_key_info() {
/** @brief /** @brief
Get metadata info stored in status.tokudb Get metadata info stored in status.tokudb
*/ */
int ha_tokudb::get_status() { int ha_tokudb::get_status(DB_TXN* txn) {
TOKUDB_DBUG_ENTER("ha_tokudb::get_status"); TOKUDB_DBUG_ENTER("ha_tokudb::get_status");
DB_TXN* txn = NULL;
DBT key, value; DBT key, value;
HA_METADATA_KEY curr_key; HA_METADATA_KEY curr_key;
int error; int error;
// //
// open status.tokudb // open status.tokudb
// //
...@@ -2939,7 +2938,7 @@ int ha_tokudb::get_status() { ...@@ -2939,7 +2938,7 @@ int ha_tokudb::get_status() {
error = open_status_dictionary( error = open_status_dictionary(
&share->status_block, &share->status_block,
share->table_name, share->table_name,
NULL txn
); );
if (error) { if (error) {
goto cleanup; goto cleanup;
...@@ -2954,8 +2953,6 @@ int ha_tokudb::get_status() { ...@@ -2954,8 +2953,6 @@ int ha_tokudb::get_status() {
key.data = &curr_key; key.data = &curr_key;
key.size = sizeof(curr_key); key.size = sizeof(curr_key);
value.flags = DB_DBT_USERMEM; value.flags = DB_DBT_USERMEM;
error = db_env->txn_begin(db_env, 0, &txn, 0);
if (error) { goto cleanup; }
assert(share->status_block); assert(share->status_block);
// //
...@@ -3037,9 +3034,6 @@ int ha_tokudb::get_status() { ...@@ -3037,9 +3034,6 @@ int ha_tokudb::get_status() {
error = 0; error = 0;
cleanup: cleanup:
if (txn) {
commit_txn(txn,0);
}
TOKUDB_DBUG_RETURN(error); TOKUDB_DBUG_RETURN(error);
} }
...@@ -6484,13 +6478,17 @@ int ha_tokudb::create(const char *name, TABLE * form, HA_CREATE_INFO * create_in ...@@ -6484,13 +6478,17 @@ int ha_tokudb::create(const char *name, TABLE * form, HA_CREATE_INFO * create_in
uint version; uint version;
uint capabilities; uint capabilities;
DB_TXN* txn = NULL; DB_TXN* txn = NULL;
bool do_commit = false;
char* newname = NULL; char* newname = NULL;
KEY_AND_COL_INFO kc_info; KEY_AND_COL_INFO kc_info;
tokudb_trx_data *trx = NULL;
bool create_from_engine= (create_info->table_options & HA_OPTION_CREATE_FROM_ENGINE); bool create_from_engine= (create_info->table_options & HA_OPTION_CREATE_FROM_ENGINE);
bzero(&kc_info, sizeof(kc_info)); bzero(&kc_info, sizeof(kc_info));
pthread_mutex_lock(&tokudb_meta_mutex); pthread_mutex_lock(&tokudb_meta_mutex);
trx = (tokudb_trx_data *) thd_data_get(ha_thd(), tokudb_hton->slot);
if (create_from_engine) { if (create_from_engine) {
// table already exists, nothing to do // table already exists, nothing to do
error = 0; error = 0;
...@@ -6501,9 +6499,15 @@ int ha_tokudb::create(const char *name, TABLE * form, HA_CREATE_INFO * create_in ...@@ -6501,9 +6499,15 @@ int ha_tokudb::create(const char *name, TABLE * form, HA_CREATE_INFO * create_in
newname = (char *)my_malloc(get_max_dict_name_path_length(name),MYF(MY_WME)); newname = (char *)my_malloc(get_max_dict_name_path_length(name),MYF(MY_WME));
if (newname == NULL){ error = ENOMEM; goto cleanup;} if (newname == NULL){ error = ENOMEM; goto cleanup;}
error = db_env->txn_begin(db_env, 0, &txn, 0); if (trx && trx->sub_sp_level) {
if (error) { goto cleanup; } txn = trx->sub_sp_level;
}
else {
do_commit = true;
error = db_env->txn_begin(db_env, 0, &txn, 0);
if (error) { goto cleanup; }
}
primary_key = form->s->primary_key; primary_key = form->s->primary_key;
hidden_primary_key = (primary_key >= MAX_KEY) ? TOKUDB_HIDDEN_PRIMARY_KEY_LENGTH : 0; hidden_primary_key = (primary_key >= MAX_KEY) ? TOKUDB_HIDDEN_PRIMARY_KEY_LENGTH : 0;
if (hidden_primary_key) { if (hidden_primary_key) {
...@@ -6579,7 +6583,7 @@ int ha_tokudb::create(const char *name, TABLE * form, HA_CREATE_INFO * create_in ...@@ -6579,7 +6583,7 @@ int ha_tokudb::create(const char *name, TABLE * form, HA_CREATE_INFO * create_in
assert(r==0); assert(r==0);
} }
free_key_and_col_info(&kc_info); free_key_and_col_info(&kc_info);
if (txn) { if (do_commit && txn) {
if (error) { if (error) {
abort_txn(txn); abort_txn(txn);
} }
......
...@@ -358,7 +358,7 @@ class ha_tokudb : public handler { ...@@ -358,7 +358,7 @@ class ha_tokudb : public handler {
int estimate_num_rows(DB* db, u_int64_t* num_rows, DB_TXN* txn); int estimate_num_rows(DB* db, u_int64_t* num_rows, DB_TXN* txn);
bool has_auto_increment_flag(uint* index); bool has_auto_increment_flag(uint* index);
int write_frm_data(DB* db, DB_TXN* txn, const char* frm_name); int write_frm_data(DB* db, DB_TXN* txn, const char* frm_name);
int verify_frm_data(const char* frm_name); int verify_frm_data(const char* frm_name, DB_TXN* trans);
int write_to_status(DB* db, HA_METADATA_KEY curr_key_data, void* data, uint size, DB_TXN* txn ); int write_to_status(DB* db, HA_METADATA_KEY curr_key_data, void* data, uint size, DB_TXN* txn );
int write_metadata(DB* db, void* key, uint key_size, void* data, uint data_size, DB_TXN* txn ); int write_metadata(DB* db, void* key, uint key_size, void* data, uint data_size, DB_TXN* txn );
int remove_metadata(DB* db, void* key_data, uint key_size, DB_TXN* transaction); int remove_metadata(DB* db, void* key_data, uint key_size, DB_TXN* transaction);
...@@ -517,7 +517,7 @@ class ha_tokudb : public handler { ...@@ -517,7 +517,7 @@ class ha_tokudb : public handler {
u_int32_t get_cursor_isolation_flags(enum thr_lock_type lock_type, THD* thd); u_int32_t get_cursor_isolation_flags(enum thr_lock_type lock_type, THD* thd);
THR_LOCK_DATA **store_lock(THD * thd, THR_LOCK_DATA ** to, enum thr_lock_type lock_type); THR_LOCK_DATA **store_lock(THD * thd, THR_LOCK_DATA ** to, enum thr_lock_type lock_type);
int get_status(); int get_status(DB_TXN* trans);
void init_hidden_prim_key_info(); void init_hidden_prim_key_info();
inline void get_auto_primary_key(uchar * to) { inline void get_auto_primary_key(uchar * to) {
pthread_mutex_lock(&share->mutex); pthread_mutex_lock(&share->mutex);
......
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