Commit cd791c32 authored by Zardosht Kasheff's avatar Zardosht Kasheff Committed by Yoni Fogel

closes #5651, make closing a cachefile cheaper

git-svn-id: file:///svn/toku/tokudb@49470 c7de825b-a66e-492c-adef-691d508d4ae1
parent ddfd46fb
...@@ -2311,26 +2311,27 @@ static void cachetable_flush_cachefile(CACHETABLE ct, CACHEFILE cf) { ...@@ -2311,26 +2311,27 @@ static void cachetable_flush_cachefile(CACHETABLE ct, CACHEFILE cf) {
XMALLOC_N(list_size, list); XMALLOC_N(list_size, list);
ct->list.read_list_lock(); ct->list.read_list_lock();
PAIR p;
//Make a list of pairs that belong to this cachefile. //Make a list of pairs that belong to this cachefile.
for (i=0; i < ct->list.m_table_size; i++) { for (i = 0, p = ct->list.m_checkpoint_head;
PAIR p; i < ct->list.m_n_in_table;
for (p = ct->list.m_table[i]; p; p = p->hash_chain) { i++, p = p->clock_next)
if (cf == 0 || p->cachefile == cf) { {
if (num_pairs == list_size) { if (cf == 0 || p->cachefile == cf) {
list_size *= 2; if (num_pairs == list_size) {
XREALLOC_N(list_size, list); list_size *= 2;
} XREALLOC_N(list_size, list);
list[num_pairs++] = p;
} }
list[num_pairs++] = p;
} }
} }
ct->list.read_list_unlock(); ct->list.read_list_unlock();
// first write out dirty PAIRs // first write out dirty PAIRs
BACKGROUND_JOB_MANAGER bjm = NULL; BACKGROUND_JOB_MANAGER bjm = NULL;
bjm_init(&bjm); bjm_init(&bjm);
for (i=0; i < num_pairs; i++) { for (i=0; i < num_pairs; i++) {
PAIR p = list[i]; p = list[i];
pair_lock(p); pair_lock(p);
assert(p->value_rwlock.users() == 0); assert(p->value_rwlock.users() == 0);
assert(nb_mutex_users(&p->disk_nb_mutex) == 0); assert(nb_mutex_users(&p->disk_nb_mutex) == 0);
...@@ -2351,7 +2352,7 @@ static void cachetable_flush_cachefile(CACHETABLE ct, CACHEFILE cf) { ...@@ -2351,7 +2352,7 @@ static void cachetable_flush_cachefile(CACHETABLE ct, CACHEFILE cf) {
// now get rid of everything // now get rid of everything
ct->list.write_list_lock(); ct->list.write_list_lock();
for (i=0; i < num_pairs; i++) { for (i=0; i < num_pairs; i++) {
PAIR p = list[i]; p = list[i];
pair_lock(p); pair_lock(p);
assert(p->value_rwlock.users() == 0); assert(p->value_rwlock.users() == 0);
assert(nb_mutex_users(&p->disk_nb_mutex) == 0); assert(nb_mutex_users(&p->disk_nb_mutex) == 0);
...@@ -2366,12 +2367,13 @@ static void cachetable_flush_cachefile(CACHETABLE ct, CACHEFILE cf) { ...@@ -2366,12 +2367,13 @@ static void cachetable_flush_cachefile(CACHETABLE ct, CACHEFILE cf) {
// assert here that cachefile is flushed by checking // assert here that cachefile is flushed by checking
// pair_list and finding no pairs belonging to this cachefile // pair_list and finding no pairs belonging to this cachefile
// Make a list of pairs that belong to this cachefile. // Make a list of pairs that belong to this cachefile.
for (i=0; i < ct->list.m_table_size; i++) {
PAIR p; for (i = 0, p = ct->list.m_checkpoint_head;
for (p = ct->list.m_table[i]; p; p = p->hash_chain) { i < ct->list.m_n_in_table;
assert(p->cachefile != cf); i++, p = p->clock_next)
} {
} assert(p->cachefile != cf);
}
ct->list.write_list_unlock(); ct->list.write_list_unlock();
if (cf) { if (cf) {
bjm_reset(cf->bjm); bjm_reset(cf->bjm);
......
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