Commit 1a9d2834 authored by Zardosht Kasheff's avatar Zardosht Kasheff Committed by Yoni Fogel

[t:4872], remove more superfluous usage of ydb lock

git-svn-id: file:///svn/toku/tokudb@44097 c7de825b-a66e-492c-adef-691d508d4ae1
parent d0c78280
...@@ -99,18 +99,16 @@ int toku_ydb_do_error (const DB_ENV *dbenv, int error, const char *fmt, ...) { ...@@ -99,18 +99,16 @@ int toku_ydb_do_error (const DB_ENV *dbenv, int error, const char *fmt, ...) {
return error; return error;
} }
/** Handle errors on an environment, guarded by the ydb lock /** Handle errors on an environment,
\param dbenv The environment that is subject to errors \param dbenv The environment that is subject to errors
\param error The error code \param error The error code
\param fmt The format string for additional variable arguments to \param fmt The format string for additional variable arguments to
be printed */ be printed */
void toku_locked_env_err(const DB_ENV * env, int error, const char *fmt, ...) { void toku_env_err(const DB_ENV * env, int error, const char *fmt, ...) {
toku_ydb_lock();
va_list ap; va_list ap;
va_start(ap, fmt); va_start(ap, fmt);
toku_ydb_error_all_cases(env, error, FALSE, TRUE, fmt, ap); toku_ydb_error_all_cases(env, error, FALSE, TRUE, fmt, ap);
va_end(ap); va_end(ap);
toku_ydb_unlock();
} }
......
...@@ -192,7 +192,7 @@ void toku_ydb_notef(const char *, ...); ...@@ -192,7 +192,7 @@ void toku_ydb_notef(const char *, ...);
/* Environment related errors */ /* Environment related errors */
int toku_env_is_panicked(DB_ENV *dbenv); int toku_env_is_panicked(DB_ENV *dbenv);
void toku_locked_env_err(const DB_ENV * env, int error, const char *fmt, ...) void toku_env_err(const DB_ENV * env, int error, const char *fmt, ...)
__attribute__((__format__(__printf__, 3, 4))); __attribute__((__format__(__printf__, 3, 4)));
typedef enum __toku_isolation_level { typedef enum __toku_isolation_level {
......
...@@ -1435,13 +1435,13 @@ toku_env_txn_checkpoint(DB_ENV * env, u_int32_t kbyte __attribute__((__unused__) ...@@ -1435,13 +1435,13 @@ toku_env_txn_checkpoint(DB_ENV * env, u_int32_t kbyte __attribute__((__unused__)
} }
static int static int
toku_env_txn_stat(DB_ENV * env, DB_TXN_STAT ** UU(statp), u_int32_t UU(flags)) { env_txn_stat(DB_ENV * env, DB_TXN_STAT ** UU(statp), u_int32_t UU(flags)) {
HANDLE_PANICKED_ENV(env); HANDLE_PANICKED_ENV(env);
return 1; return 1;
} }
static int static int
toku_env_txn_xa_recover (DB_ENV *env, TOKU_XA_XID xids[/*count*/], long count, /*out*/ long *retp, u_int32_t flags) { env_txn_xa_recover (DB_ENV *env, TOKU_XA_XID xids[/*count*/], long count, /*out*/ long *retp, u_int32_t flags) {
struct tokulogger_preplist *MALLOC_N(count,preps); struct tokulogger_preplist *MALLOC_N(count,preps);
int r = toku_logger_recover_txn(env->i->logger, preps, count, retp, flags); int r = toku_logger_recover_txn(env->i->logger, preps, count, retp, flags);
if (r==0) { if (r==0) {
...@@ -1455,7 +1455,7 @@ toku_env_txn_xa_recover (DB_ENV *env, TOKU_XA_XID xids[/*count*/], long count, / ...@@ -1455,7 +1455,7 @@ toku_env_txn_xa_recover (DB_ENV *env, TOKU_XA_XID xids[/*count*/], long count, /
} }
static int static int
toku_env_txn_recover (DB_ENV *env, DB_PREPLIST preplist[/*count*/], long count, /*out*/ long *retp, u_int32_t flags) { env_txn_recover (DB_ENV *env, DB_PREPLIST preplist[/*count*/], long count, /*out*/ long *retp, u_int32_t flags) {
struct tokulogger_preplist *MALLOC_N(count,preps); struct tokulogger_preplist *MALLOC_N(count,preps);
int r = toku_logger_recover_txn(env->i->logger, preps, count, retp, flags); int r = toku_logger_recover_txn(env->i->logger, preps, count, retp, flags);
if (r==0) { if (r==0) {
...@@ -1471,33 +1471,10 @@ toku_env_txn_recover (DB_ENV *env, DB_PREPLIST preplist[/*count*/], long count, ...@@ -1471,33 +1471,10 @@ toku_env_txn_recover (DB_ENV *env, DB_PREPLIST preplist[/*count*/], long count,
static int static int
locked_env_txn_recover (DB_ENV *env, DB_PREPLIST preplist[/*count*/], long count, /*out*/ long *retp, u_int32_t flags) { env_get_txn_from_xid (DB_ENV *env, /*in*/ TOKU_XA_XID *xid, /*out*/ DB_TXN **txnp) {
toku_ydb_lock();
int r = toku_env_txn_recover(env, preplist, count, retp, flags);
toku_ydb_unlock();
return r;
}
static int
locked_env_txn_xa_recover (DB_ENV *env, TOKU_XA_XID xids[/*count*/], long count, /*out*/ long *retp, u_int32_t flags) {
toku_ydb_lock();
int r = toku_env_txn_xa_recover(env, xids, count, retp, flags);
toku_ydb_unlock();
return r;
}
static int
toku_env_get_txn_from_xid (DB_ENV *env, /*in*/ TOKU_XA_XID *xid, /*out*/ DB_TXN **txnp) {
return toku_txn_manager_get_txn_from_xid(toku_logger_get_txn_manager(env->i->logger), xid, txnp); return toku_txn_manager_get_txn_from_xid(toku_logger_get_txn_manager(env->i->logger), xid, txnp);
} }
static int
locked_env_get_txn_from_xid (DB_ENV *env, /*in*/ TOKU_XA_XID *xid, /*out*/ DB_TXN **txnp) {
toku_ydb_lock();
int r = toku_env_get_txn_from_xid(env, xid, txnp);
toku_ydb_unlock();
return r;
}
static int static int
locked_env_log_archive(DB_ENV * env, char **list[], u_int32_t flags) { locked_env_log_archive(DB_ENV * env, char **list[], u_int32_t flags) {
toku_ydb_lock(); int r = toku_env_log_archive(env, list, flags); toku_ydb_unlock(); return r; toku_ydb_lock(); int r = toku_env_log_archive(env, list, flags); toku_ydb_unlock(); return r;
...@@ -1514,11 +1491,6 @@ locked_env_set_cachesize(DB_ENV *env, u_int32_t gbytes, u_int32_t bytes, int nca ...@@ -1514,11 +1491,6 @@ locked_env_set_cachesize(DB_ENV *env, u_int32_t gbytes, u_int32_t bytes, int nca
} }
static int
locked_env_txn_stat(DB_ENV * env, DB_TXN_STAT ** statp, u_int32_t flags) {
toku_ydb_lock(); int r = toku_env_txn_stat(env, statp, flags); toku_ydb_unlock(); return r;
}
static int static int
env_checkpointing_set_period(DB_ENV * env, u_int32_t seconds) { env_checkpointing_set_period(DB_ENV * env, u_int32_t seconds) {
HANDLE_PANICKED_ENV(env); HANDLE_PANICKED_ENV(env);
...@@ -1687,27 +1659,11 @@ env_set_default_bt_compare(DB_ENV * env, int (*bt_compare) (DB *, const DBT *, c ...@@ -1687,27 +1659,11 @@ env_set_default_bt_compare(DB_ENV * env, int (*bt_compare) (DB *, const DBT *, c
return r; return r;
} }
static int
locked_env_set_default_bt_compare(DB_ENV * env, int (*bt_compare) (DB *, const DBT *, const DBT *)) {
toku_ydb_lock();
int r = env_set_default_bt_compare(env, bt_compare);
toku_ydb_unlock();
return r;
}
static void static void
env_set_update (DB_ENV *env, int (*update_function)(DB *, const DBT *key, const DBT *old_val, const DBT *extra, void (*set_val)(const DBT *new_val, void *set_extra), void *set_extra)) { env_set_update (DB_ENV *env, int (*update_function)(DB *, const DBT *key, const DBT *old_val, const DBT *extra, void (*set_val)(const DBT *new_val, void *set_extra), void *set_extra)) {
env->i->update_function = update_function; env->i->update_function = update_function;
} }
static void
locked_env_set_update (DB_ENV *env, int (*update_function)(DB *, const DBT *key, const DBT *old_val, const DBT *extra, void (*set_val)(const DBT *new_val, void *set_extra), void *set_extra)) {
toku_ydb_lock();
env_set_update (env, update_function);
toku_ydb_unlock();
}
static int static int
env_set_generate_row_callback_for_put(DB_ENV *env, generate_row_for_put_func generate_row_for_put) { env_set_generate_row_callback_for_put(DB_ENV *env, generate_row_for_put_func generate_row_for_put) {
...@@ -1730,23 +1686,6 @@ env_set_generate_row_callback_for_del(DB_ENV *env, generate_row_for_del_func gen ...@@ -1730,23 +1686,6 @@ env_set_generate_row_callback_for_del(DB_ENV *env, generate_row_for_del_func gen
} }
return r; return r;
} }
static int
locked_env_set_generate_row_callback_for_put(DB_ENV *env, generate_row_for_put_func generate_row_for_put) {
toku_ydb_lock();
int r = env_set_generate_row_callback_for_put(env, generate_row_for_put);
toku_ydb_unlock();
return r;
}
static int
locked_env_set_generate_row_callback_for_del(DB_ENV *env, generate_row_for_del_func generate_row_for_del) {
toku_ydb_lock();
int r = env_set_generate_row_callback_for_del(env, generate_row_for_del);
toku_ydb_unlock();
return r;
}
static int static int
env_set_redzone(DB_ENV *env, int redzone) { env_set_redzone(DB_ENV *env, int redzone) {
HANDLE_PANICKED_ENV(env); HANDLE_PANICKED_ENV(env);
...@@ -1760,42 +1699,18 @@ env_set_redzone(DB_ENV *env, int redzone) { ...@@ -1760,42 +1699,18 @@ env_set_redzone(DB_ENV *env, int redzone) {
return r; return r;
} }
static int
locked_env_set_redzone(DB_ENV *env, int redzone) {
toku_ydb_lock();
int r= env_set_redzone(env, redzone);
toku_ydb_unlock();
return r;
}
static int static int
env_get_lock_timeout(DB_ENV *env, uint64_t *lock_timeout_msec) { env_get_lock_timeout(DB_ENV *env, uint64_t *lock_timeout_msec) {
toku_ltm_get_lock_wait_time(env->i->ltm, lock_timeout_msec); toku_ltm_get_lock_wait_time(env->i->ltm, lock_timeout_msec);
return 0; return 0;
} }
static int
locked_env_get_lock_timeout(DB_ENV *env, uint64_t *lock_timeout_msec) {
toku_ydb_lock();
int r = env_get_lock_timeout(env, lock_timeout_msec);
toku_ydb_unlock();
return r;
}
static int static int
env_set_lock_timeout(DB_ENV *env, uint64_t lock_timeout_msec) { env_set_lock_timeout(DB_ENV *env, uint64_t lock_timeout_msec) {
toku_ltm_set_lock_wait_time(env->i->ltm, lock_timeout_msec); toku_ltm_set_lock_wait_time(env->i->ltm, lock_timeout_msec);
return 0; return 0;
} }
static int
locked_env_set_lock_timeout(DB_ENV *env, uint64_t lock_timeout_msec) {
toku_ydb_lock();
int r = env_set_lock_timeout(env, lock_timeout_msec);
toku_ydb_unlock();
return r;
}
static void static void
format_time(const time_t *timer, char *buf) { format_time(const time_t *timer, char *buf) {
ctime_r(timer, buf); ctime_r(timer, buf);
...@@ -2307,32 +2222,21 @@ toku_env_create(DB_ENV ** envp, u_int32_t flags) { ...@@ -2307,32 +2222,21 @@ toku_env_create(DB_ENV ** envp, u_int32_t flags) {
memset(result, 0, sizeof *result); memset(result, 0, sizeof *result);
// locked methods // locked methods
result->err = (void (*)(const DB_ENV * env, int error, const char *fmt, ...)) toku_locked_env_err; result->err = (void (*)(const DB_ENV * env, int error, const char *fmt, ...)) toku_env_err;
#define SENV(name) result->name = locked_env_ ## name #define SENV(name) result->name = locked_env_ ## name
SENV(dbremove); SENV(dbremove);
SENV(dbrename); SENV(dbrename);
SENV(set_default_bt_compare);
SENV(set_update);
SENV(set_generate_row_callback_for_put);
SENV(set_generate_row_callback_for_del);
SENV(checkpointing_set_period); SENV(checkpointing_set_period);
SENV(checkpointing_get_period); SENV(checkpointing_get_period);
SENV(cleaner_set_period); SENV(cleaner_set_period);
SENV(cleaner_get_period); SENV(cleaner_get_period);
SENV(cleaner_set_iterations); SENV(cleaner_set_iterations);
SENV(cleaner_get_iterations); SENV(cleaner_get_iterations);
SENV(txn_recover);
SENV(txn_xa_recover);
SENV(get_txn_from_xid);
SENV(log_flush); SENV(log_flush);
//SENV(set_noticecall); //SENV(set_noticecall);
SENV(set_cachesize); SENV(set_cachesize);
SENV(log_archive); SENV(log_archive);
SENV(txn_stat);
SENV(set_redzone);
SENV(create_indexer); SENV(create_indexer);
SENV(get_lock_timeout);
SENV(set_lock_timeout);
#undef SENV #undef SENV
#define USENV(name) result->name = env_ ## name #define USENV(name) result->name = env_ ## name
// methods with locking done internally // methods with locking done internally
...@@ -2342,6 +2246,10 @@ toku_env_create(DB_ENV ** envp, u_int32_t flags) { ...@@ -2342,6 +2246,10 @@ toku_env_create(DB_ENV ** envp, u_int32_t flags) {
// unlocked methods // unlocked methods
USENV(open); USENV(open);
USENV(close); USENV(close);
USENV(set_default_bt_compare);
USENV(set_update);
USENV(set_generate_row_callback_for_put);
USENV(set_generate_row_callback_for_del);
USENV(set_lg_bsize); USENV(set_lg_bsize);
USENV(set_lg_dir); USENV(set_lg_dir);
USENV(set_lg_max); USENV(set_lg_max);
...@@ -2365,6 +2273,13 @@ toku_env_create(DB_ENV ** envp, u_int32_t flags) { ...@@ -2365,6 +2273,13 @@ toku_env_create(DB_ENV ** envp, u_int32_t flags) {
USENV(set_flags); USENV(set_flags);
USENV(set_tmp_dir); USENV(set_tmp_dir);
USENV(set_verbose); USENV(set_verbose);
USENV(txn_recover);
USENV(txn_xa_recover);
USENV(get_txn_from_xid);
USENV(txn_stat);
USENV(get_lock_timeout);
USENV(set_lock_timeout);
USENV(set_redzone);
#undef USENV #undef USENV
......
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