Commit f3acf3d4 authored by Rich Prohaska's avatar Rich Prohaska

fix the benchmark-test running out of vm space when running with large values

(--valsize 1024).



git-svn-id: file:///svn/tokudb@493 c7de825b-a66e-492c-adef-691d508d4ae1
parent 407fb254
...@@ -82,7 +82,7 @@ void fix_up_parent_pointers_of_children (BRT t, BRTNODE node) { ...@@ -82,7 +82,7 @@ void fix_up_parent_pointers_of_children (BRT t, BRTNODE node) {
BRTNODE child = v; BRTNODE child = v;
//printf("%s:%d pin %p\n", __FILE__, __LINE__, v); //printf("%s:%d pin %p\n", __FILE__, __LINE__, v);
child->parent_brtnode = node; child->parent_brtnode = node;
r=cachetable_unpin(t->cf, node->u.n.children[i], 0); r=cachetable_unpin_size(t->cf, node->u.n.children[i], child->dirty, brtnode_size(child));
} }
} }
} }
...@@ -97,7 +97,7 @@ void fix_up_parent_pointers_of_children_now_that_parent_is_gone (CACHEFILE cf, B ...@@ -97,7 +97,7 @@ void fix_up_parent_pointers_of_children_now_that_parent_is_gone (CACHEFILE cf, B
BRTNODE child = v; BRTNODE child = v;
//printf("%s:%d pin %p\n", __FILE__, __LINE__, v); //printf("%s:%d pin %p\n", __FILE__, __LINE__, v);
child->parent_brtnode = 0; child->parent_brtnode = 0;
r=cachetable_unpin(cf, node->u.n.children[i], 0); r=cachetable_unpin_size(cf, node->u.n.children[i], child->dirty, brtnode_size(child));
} }
} }
} }
...@@ -1311,16 +1311,19 @@ int brt_root_put_cmd(BRT brt, BRT_CMD *cmd, TOKUTXN txn) { ...@@ -1311,16 +1311,19 @@ int brt_root_put_cmd(BRT brt, BRT_CMD *cmd, TOKUTXN txn) {
assert(nodeb->nodesize>0); assert(nodeb->nodesize>0);
} }
int dirty; int dirty;
long size;
if (did_split) { if (did_split) {
r = brt_init_new_root(brt, nodea, nodeb, splitk, rootp); r = brt_init_new_root(brt, nodea, nodeb, splitk, rootp);
assert(r == 0); assert(r == 0);
dirty = 1; dirty = 1;
size = 0;
} else { } else {
if (node->height>0) if (node->height>0)
assert(node->u.n.n_children<=TREE_FANOUT); assert(node->u.n.n_children<=TREE_FANOUT);
dirty = node->dirty; dirty = node->dirty;
size = brtnode_size(node);
} }
cachetable_unpin_size(brt->cf, *rootp, dirty, 0); cachetable_unpin_size(brt->cf, *rootp, dirty, size);
r = unpin_brt_header(brt); r = unpin_brt_header(brt);
assert(r == 0); assert(r == 0);
//assert(0==cachetable_assert_all_unpinned(brt->cachetable)); //assert(0==cachetable_assert_all_unpinned(brt->cachetable));
......
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