Commit 21975113 authored by Barry Perlman's avatar Barry Perlman Committed by Yoni Fogel

Add some debug info

git-svn-id: file:///svn/toku/tokudb@11715 c7de825b-a66e-492c-adef-691d508d4ae1
parent ff57e4c6
...@@ -983,6 +983,14 @@ write_pair_for_checkpoint (CACHETABLE ct, PAIR p) ...@@ -983,6 +983,14 @@ write_pair_for_checkpoint (CACHETABLE ct, PAIR p)
} }
} }
// for debugging
// valid only if this function is called only by a single thread
static u_int64_t get_and_pin_footprint = 0;
static CACHEFILE get_and_pin_cachefile = NULL;
static CACHEKEY get_and_pin_key = {0};
static u_int32_t get_and_pin_fullhash = 0;
int toku_cachetable_get_and_pin(CACHEFILE cachefile, CACHEKEY key, u_int32_t fullhash, void**value, long *sizep, int toku_cachetable_get_and_pin(CACHEFILE cachefile, CACHEKEY key, u_int32_t fullhash, void**value, long *sizep,
CACHETABLE_FLUSH_CALLBACK flush_callback, CACHETABLE_FLUSH_CALLBACK flush_callback,
...@@ -990,8 +998,18 @@ int toku_cachetable_get_and_pin(CACHEFILE cachefile, CACHEKEY key, u_int32_t ful ...@@ -990,8 +998,18 @@ int toku_cachetable_get_and_pin(CACHEFILE cachefile, CACHEKEY key, u_int32_t ful
CACHETABLE ct = cachefile->cachetable; CACHETABLE ct = cachefile->cachetable;
PAIR p; PAIR p;
int count=0; int count=0;
get_and_pin_footprint = 1;
cachetable_lock(ct); cachetable_lock(ct);
get_and_pin_cachefile = cachefile;
get_and_pin_key = key;
get_and_pin_fullhash = fullhash;
get_and_pin_footprint = 2;
cachetable_wait_write(ct); cachetable_wait_write(ct);
get_and_pin_footprint = 3;
for (p=ct->table[fullhash&(ct->table_size-1)]; p; p=p->hash_chain) { for (p=ct->table[fullhash&(ct->table_size-1)]; p; p=p->hash_chain) {
count++; count++;
if (p->key.b==key.b && p->cachefile==cachefile) { if (p->key.b==key.b && p->cachefile==cachefile) {
...@@ -1010,7 +1028,9 @@ int toku_cachetable_get_and_pin(CACHEFILE cachefile, CACHEKEY key, u_int32_t ful ...@@ -1010,7 +1028,9 @@ int toku_cachetable_get_and_pin(CACHEFILE cachefile, CACHEKEY key, u_int32_t ful
#endif #endif
} }
if (p->checkpoint_pending) { if (p->checkpoint_pending) {
get_and_pin_footprint = 4;
rwlock_write_lock(&p->rwlock, ct->mutex); rwlock_write_lock(&p->rwlock, ct->mutex);
get_and_pin_footprint = 5;
write_pair_for_checkpoint(ct, p); // releases the pair_write_lock, but not the cachetable lock write_pair_for_checkpoint(ct, p); // releases the pair_write_lock, but not the cachetable lock
} }
// still have the cachetable lock // still have the cachetable lock
...@@ -1023,11 +1043,16 @@ int toku_cachetable_get_and_pin(CACHEFILE cachefile, CACHEKEY key, u_int32_t ful ...@@ -1023,11 +1043,16 @@ int toku_cachetable_get_and_pin(CACHEFILE cachefile, CACHEKEY key, u_int32_t ful
// lock. The work-around is to have an unfair rwlock mechanism that favors the // lock. The work-around is to have an unfair rwlock mechanism that favors the
// reader. // reader.
#ifdef BRT_LEVEL_STRADDLE_CALLBACK_LOGIC_NOT_READY #ifdef BRT_LEVEL_STRADDLE_CALLBACK_LOGIC_NOT_READY
if (STRADDLE_HACK_INSIDE_CALLBACK) if (STRADDLE_HACK_INSIDE_CALLBACK) {
get_and_pin_footprint = 6;
rwlock_prefer_read_lock(&p->rwlock, ct->mutex); rwlock_prefer_read_lock(&p->rwlock, ct->mutex);
}
else else
#endif #endif
rwlock_read_lock(&p->rwlock, ct->mutex); {
get_and_pin_footprint = 7;
rwlock_read_lock(&p->rwlock, ct->mutex);
}
#if TOKU_DO_WAIT_TIME #if TOKU_DO_WAIT_TIME
if (do_wait_time) { if (do_wait_time) {
struct timeval tnow; struct timeval tnow;
...@@ -1035,11 +1060,14 @@ int toku_cachetable_get_and_pin(CACHEFILE cachefile, CACHEKEY key, u_int32_t ful ...@@ -1035,11 +1060,14 @@ int toku_cachetable_get_and_pin(CACHEFILE cachefile, CACHEKEY key, u_int32_t ful
cachetable_wait_time += tdelta(&tnow, &t0); cachetable_wait_time += tdelta(&tnow, &t0);
} }
#endif #endif
get_and_pin_footprint = 8;
if (p->state == CTPAIR_INVALID) { if (p->state == CTPAIR_INVALID) {
get_and_pin_footprint = 9;
rwlock_read_unlock(&p->rwlock); rwlock_read_unlock(&p->rwlock);
if (rwlock_users(&p->rwlock) == 0) if (rwlock_users(&p->rwlock) == 0)
ctpair_destroy(p); ctpair_destroy(p);
cachetable_unlock(ct); cachetable_unlock(ct);
get_and_pin_footprint = 0;
return ENODEV; return ENODEV;
} }
lru_touch(ct,p); lru_touch(ct,p);
...@@ -1049,15 +1077,18 @@ int toku_cachetable_get_and_pin(CACHEFILE cachefile, CACHEKEY key, u_int32_t ful ...@@ -1049,15 +1077,18 @@ int toku_cachetable_get_and_pin(CACHEFILE cachefile, CACHEKEY key, u_int32_t ful
note_hash_count(count); note_hash_count(count);
cachetable_unlock(ct); cachetable_unlock(ct);
WHEN_TRACE_CT(printf("%s:%d cachtable_get_and_pin(%lld)--> %p\n", __FILE__, __LINE__, key, *value)); WHEN_TRACE_CT(printf("%s:%d cachtable_get_and_pin(%lld)--> %p\n", __FILE__, __LINE__, key, *value));
get_and_pin_footprint = 0;
return 0; return 0;
} }
} }
get_and_pin_footprint = 9;
note_hash_count(count); note_hash_count(count);
int r; int r;
// Note. hashit(t,key) may have changed as a result of flushing. But fullhash won't have changed. // Note. hashit(t,key) may have changed as a result of flushing. But fullhash won't have changed.
{ {
p = cachetable_insert_at(ct, cachefile, key, zero_value, CTPAIR_READING, fullhash, zero_size, flush_callback, fetch_callback, extraargs, CACHETABLE_CLEAN, ZERO_LSN); p = cachetable_insert_at(ct, cachefile, key, zero_value, CTPAIR_READING, fullhash, zero_size, flush_callback, fetch_callback, extraargs, CACHETABLE_CLEAN, ZERO_LSN);
assert(p); assert(p);
get_and_pin_footprint = 10;
rwlock_write_lock(&p->rwlock, ct->mutex); rwlock_write_lock(&p->rwlock, ct->mutex);
#if TOKU_DO_WAIT_TIME #if TOKU_DO_WAIT_TIME
struct timeval t0; struct timeval t0;
...@@ -1066,6 +1097,7 @@ int toku_cachetable_get_and_pin(CACHEFILE cachefile, CACHEKEY key, u_int32_t ful ...@@ -1066,6 +1097,7 @@ int toku_cachetable_get_and_pin(CACHEFILE cachefile, CACHEKEY key, u_int32_t ful
r = cachetable_fetch_pair(ct, cachefile, p); r = cachetable_fetch_pair(ct, cachefile, p);
if (r) { if (r) {
cachetable_unlock(ct); cachetable_unlock(ct);
get_and_pin_footprint = 0;
return r; return r;
} }
cachetable_miss++; cachetable_miss++;
...@@ -1074,15 +1106,18 @@ int toku_cachetable_get_and_pin(CACHEFILE cachefile, CACHEKEY key, u_int32_t ful ...@@ -1074,15 +1106,18 @@ int toku_cachetable_get_and_pin(CACHEFILE cachefile, CACHEKEY key, u_int32_t ful
gettimeofday(&tnow, NULL); gettimeofday(&tnow, NULL);
cachetable_miss_time += tdelta(&tnow, &t0); cachetable_miss_time += tdelta(&tnow, &t0);
#endif #endif
get_and_pin_footprint = 11;
rwlock_read_lock(&p->rwlock, ct->mutex); rwlock_read_lock(&p->rwlock, ct->mutex);
assert(p->state == CTPAIR_IDLE); assert(p->state == CTPAIR_IDLE);
*value = p->value; *value = p->value;
if (sizep) *sizep = p->size; if (sizep) *sizep = p->size;
} }
get_and_pin_footprint = 12;
r = maybe_flush_some(ct, 0); r = maybe_flush_some(ct, 0);
cachetable_unlock(ct); cachetable_unlock(ct);
WHEN_TRACE_CT(printf("%s:%d did fetch: cachtable_get_and_pin(%lld)--> %p\n", __FILE__, __LINE__, key, *value)); WHEN_TRACE_CT(printf("%s:%d did fetch: cachtable_get_and_pin(%lld)--> %p\n", __FILE__, __LINE__, key, *value));
get_and_pin_footprint = 0;
return r; return r;
} }
......
...@@ -53,11 +53,11 @@ ...@@ -53,11 +53,11 @@
#include "checkpoint.h" #include "checkpoint.h"
// breadcrumbs for debugging // breadcrumbs for debugging
static u_int64_t breadcrumb0 = 0; static u_int64_t checkpoint_breadcrumb0 = 0;
static u_int64_t breadcrumb1 = 0; static u_int64_t checkpoint_breadcrumb1 = 0;
static u_int64_t breadcrumb2 = 0; static u_int64_t checkpoint_breadcrumb2 = 0;
static u_int64_t breadcrumb3 = 0; static u_int64_t checkpoint_breadcrumb3 = 0;
static u_int64_t breadcrumb4 = 0; static u_int64_t checkpoint_breadcrumb4 = 0;
static toku_pthread_rwlock_t checkpoint_safe_lock; static toku_pthread_rwlock_t checkpoint_safe_lock;
static toku_pthread_rwlock_t multi_operation_lock; static toku_pthread_rwlock_t multi_operation_lock;
...@@ -171,28 +171,28 @@ int ...@@ -171,28 +171,28 @@ int
toku_checkpoint(CACHETABLE ct, TOKULOGGER logger, char **error_string, void (*callback_f)(void*), void * extra) { toku_checkpoint(CACHETABLE ct, TOKULOGGER logger, char **error_string, void (*callback_f)(void*), void * extra) {
int r; int r;
breadcrumb0++; checkpoint_breadcrumb0++;
assert(initialized); assert(initialized);
multi_operation_checkpoint_lock(); multi_operation_checkpoint_lock();
checkpoint_safe_checkpoint_lock(); checkpoint_safe_checkpoint_lock();
ydb_lock(); ydb_lock();
breadcrumb1++; checkpoint_breadcrumb1++;
r = toku_cachetable_begin_checkpoint(ct, logger); r = toku_cachetable_begin_checkpoint(ct, logger);
multi_operation_checkpoint_unlock(); multi_operation_checkpoint_unlock();
ydb_unlock(); ydb_unlock();
breadcrumb2++; checkpoint_breadcrumb2++;
if (r==0) { if (r==0) {
if (callback_f) if (callback_f)
callback_f(extra); // callback is called with checkpoint_safe_lock still held callback_f(extra); // callback is called with checkpoint_safe_lock still held
r = toku_cachetable_end_checkpoint(ct, logger, error_string); r = toku_cachetable_end_checkpoint(ct, logger, error_string);
} }
breadcrumb3++; checkpoint_breadcrumb3++;
checkpoint_safe_checkpoint_unlock(); checkpoint_safe_checkpoint_unlock();
breadcrumb4++; checkpoint_breadcrumb4++;
return r; return r;
} }
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