Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
433e2bab
Commit
433e2bab
authored
Mar 01, 2014
by
John Esmet
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Tests compile now
parent
f176288d
Changes
17
Hide whitespace changes
Inline
Side-by-side
Showing
17 changed files
with
136 additions
and
167 deletions
+136
-167
ft/ft-cachetable-wrappers.cc
ft/ft-cachetable-wrappers.cc
+10
-0
ft/ft-cachetable-wrappers.h
ft/ft-cachetable-wrappers.h
+15
-9
ft/ft-flusher.cc
ft/ft-flusher.cc
+1
-1
ft/ft-hot-flusher.cc
ft/ft-hot-flusher.cc
+7
-9
ft/ft-ops.cc
ft/ft-ops.cc
+14
-26
ft/ft-test-helpers.cc
ft/ft-test-helpers.cc
+1
-3
ft/ft-verify.cc
ft/ft-verify.cc
+1
-3
ft/tests/test-checkpoint-during-flush.cc
ft/tests/test-checkpoint-during-flush.cc
+12
-16
ft/tests/test-checkpoint-during-merge.cc
ft/tests/test-checkpoint-during-merge.cc
+6
-6
ft/tests/test-checkpoint-during-rebalance.cc
ft/tests/test-checkpoint-during-rebalance.cc
+11
-18
ft/tests/test-checkpoint-during-split.cc
ft/tests/test-checkpoint-during-split.cc
+18
-24
ft/tests/test-dirty-flushes-on-cleaner.cc
ft/tests/test-dirty-flushes-on-cleaner.cc
+4
-4
ft/tests/test-flushes-on-cleaner.cc
ft/tests/test-flushes-on-cleaner.cc
+12
-16
ft/tests/test-hot-with-bounds.cc
ft/tests/test-hot-with-bounds.cc
+6
-8
ft/tests/test-merges-on-cleaner.cc
ft/tests/test-merges-on-cleaner.cc
+6
-8
ft/tests/test-oldest-referenced-xid-flush.cc
ft/tests/test-oldest-referenced-xid-flush.cc
+9
-12
ft/tests/test4244.cc
ft/tests/test4244.cc
+3
-4
No files found.
ft/ft-cachetable-wrappers.cc
View file @
433e2bab
...
@@ -360,6 +360,16 @@ toku_pin_ftnode_with_dep_nodes(
...
@@ -360,6 +360,16 @@ toku_pin_ftnode_with_dep_nodes(
*
node_p
=
node
;
*
node_p
=
node
;
}
}
void
toku_pin_ftnode
(
FT
ft
,
BLOCKNUM
blocknum
,
uint32_t
fullhash
,
FTNODE_FETCH_EXTRA
bfe
,
pair_lock_type
lock_type
,
FTNODE
*
node_p
,
bool
move_messages
)
{
toku_pin_ftnode_with_dep_nodes
(
ft
,
blocknum
,
fullhash
,
bfe
,
lock_type
,
0
,
nullptr
,
node_p
,
move_messages
);
}
int
toku_maybe_pin_ftnode_clean
(
FT
ft
,
BLOCKNUM
blocknum
,
uint32_t
fullhash
,
pair_lock_type
lock_type
,
FTNODE
*
nodep
)
{
int
toku_maybe_pin_ftnode_clean
(
FT
ft
,
BLOCKNUM
blocknum
,
uint32_t
fullhash
,
pair_lock_type
lock_type
,
FTNODE
*
nodep
)
{
void
*
node_v
;
void
*
node_v
;
int
r
=
toku_cachetable_maybe_get_and_pin_clean
(
ft
->
cf
,
blocknum
,
fullhash
,
lock_type
,
&
node_v
);
int
r
=
toku_cachetable_maybe_get_and_pin_clean
(
ft
->
cf
,
blocknum
,
fullhash
,
lock_type
,
&
node_v
);
...
...
ft/ft-cachetable-wrappers.h
View file @
433e2bab
...
@@ -138,6 +138,7 @@ toku_create_new_ftnode (
...
@@ -138,6 +138,7 @@ toku_create_new_ftnode (
int
n_children
int
n_children
);
);
// This function returns a pinned ftnode to the caller.
int
int
toku_pin_ftnode_for_query
(
toku_pin_ftnode_for_query
(
FT_HANDLE
brt
,
FT_HANDLE
brt
,
...
@@ -152,15 +153,20 @@ toku_pin_ftnode_for_query(
...
@@ -152,15 +153,20 @@ toku_pin_ftnode_for_query(
bool
*
msgs_applied
bool
*
msgs_applied
);
);
/**
// Pins an ftnode without dependent pairs
* Unfortunately, this function is poorly named
void
toku_pin_ftnode
(
* as over time, client threads have also started
FT
h
,
* calling this function.
BLOCKNUM
blocknum
,
* This function returns a pinned ftnode to the caller.
uint32_t
fullhash
,
* Unlike toku_pin_ftnode, this function blocks until the node is pinned.
FTNODE_FETCH_EXTRA
bfe
,
*/
pair_lock_type
lock_type
,
void
FTNODE
*
node_p
,
toku_pin_ftnode_with_dep_nodes
(
bool
move_messages
);
// Pins an ftnode with dependent pairs
// Unlike toku_pin_ftnode_for_query, this function blocks until the node is pinned.
void
toku_pin_ftnode_with_dep_nodes
(
FT
h
,
FT
h
,
BLOCKNUM
blocknum
,
BLOCKNUM
blocknum
,
uint32_t
fullhash
,
uint32_t
fullhash
,
...
...
ft/ft-flusher.cc
View file @
433e2bab
...
@@ -496,7 +496,7 @@ ct_maybe_merge_child(struct flusher_advice *fa,
...
@@ -496,7 +496,7 @@ ct_maybe_merge_child(struct flusher_advice *fa,
toku_calculate_root_offset_pointer
(
h
,
&
root
,
&
fullhash
);
toku_calculate_root_offset_pointer
(
h
,
&
root
,
&
fullhash
);
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_full_read
(
&
bfe
,
h
);
fill_bfe_for_full_read
(
&
bfe
,
h
);
toku_pin_ftnode
_with_dep_nodes
(
h
,
root
,
fullhash
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
0
,
NULL
,
&
root_node
,
true
);
toku_pin_ftnode
(
h
,
root
,
fullhash
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
&
root_node
,
true
);
toku_assert_entire_node_in_memory
(
root_node
);
toku_assert_entire_node_in_memory
(
root_node
);
}
}
...
...
ft/ft-hot-flusher.cc
View file @
433e2bab
...
@@ -332,15 +332,13 @@ toku_ft_hot_optimize(FT_HANDLE brt, DBT* left, DBT* right,
...
@@ -332,15 +332,13 @@ toku_ft_hot_optimize(FT_HANDLE brt, DBT* left, DBT* right,
toku_calculate_root_offset_pointer
(
brt
->
ft
,
&
root_key
,
&
fullhash
);
toku_calculate_root_offset_pointer
(
brt
->
ft
,
&
root_key
,
&
fullhash
);
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_full_read
(
&
bfe
,
brt
->
ft
);
fill_bfe_for_full_read
(
&
bfe
,
brt
->
ft
);
toku_pin_ftnode_with_dep_nodes
(
brt
->
ft
,
toku_pin_ftnode
(
brt
->
ft
,
(
BLOCKNUM
)
root_key
,
(
BLOCKNUM
)
root_key
,
fullhash
,
fullhash
,
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
root
,
NULL
,
true
);
&
root
,
true
);
toku_assert_entire_node_in_memory
(
root
);
toku_assert_entire_node_in_memory
(
root
);
}
}
...
...
ft/ft-ops.cc
View file @
433e2bab
...
@@ -1674,14 +1674,12 @@ ft_init_new_root(FT ft, FTNODE oldroot, FTNODE *newrootp)
...
@@ -1674,14 +1674,12 @@ ft_init_new_root(FT ft, FTNODE oldroot, FTNODE *newrootp)
// return to caller
// return to caller
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_full_read
(
&
bfe
,
ft
);
fill_bfe_for_full_read
(
&
bfe
,
ft
);
toku_pin_ftnode
_with_dep_nodes
(
toku_pin_ftnode
(
ft
,
ft
,
old_blocknum
,
old_blocknum
,
old_fullhash
,
old_fullhash
,
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
// may_modify_node
PL_WRITE_EXPENSIVE
,
// may_modify_node
0
,
NULL
,
newrootp
,
newrootp
,
true
true
);
);
...
@@ -2793,7 +2791,7 @@ static bool process_maybe_reactive_child(FT ft, FTNODE parent, FTNODE child, int
...
@@ -2793,7 +2791,7 @@ static bool process_maybe_reactive_child(FT ft, FTNODE parent, FTNODE child, int
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_full_read
(
&
bfe
,
ft
);
fill_bfe_for_full_read
(
&
bfe
,
ft
);
FTNODE
newparent
,
newchild
;
FTNODE
newparent
,
newchild
;
toku_pin_ftnode
_with_dep_nodes
(
ft
,
parent_blocknum
,
parent_fullhash
,
&
bfe
,
PL_WRITE_CHEAP
,
0
,
nullptr
,
&
newparent
,
true
);
toku_pin_ftnode
(
ft
,
parent_blocknum
,
parent_fullhash
,
&
bfe
,
PL_WRITE_CHEAP
,
&
newparent
,
true
);
if
(
newparent
->
height
!=
parent_height
||
newparent
->
n_children
!=
parent_n_children
||
if
(
newparent
->
height
!=
parent_height
||
newparent
->
n_children
!=
parent_n_children
||
childnum
>=
newparent
->
n_children
||
toku_bnc_n_entries
(
BNC
(
newparent
,
childnum
)))
{
childnum
>=
newparent
->
n_children
||
toku_bnc_n_entries
(
BNC
(
newparent
,
childnum
)))
{
// If the height changed or childnum is now off the end, something clearly got split or merged out from under us.
// If the height changed or childnum is now off the end, something clearly got split or merged out from under us.
...
@@ -2845,7 +2843,7 @@ static bool process_maybe_reactive_child(FT ft, FTNODE parent, FTNODE child, int
...
@@ -2845,7 +2843,7 @@ static bool process_maybe_reactive_child(FT ft, FTNODE parent, FTNODE child, int
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_full_read
(
&
bfe
,
ft
);
fill_bfe_for_full_read
(
&
bfe
,
ft
);
FTNODE
newparent
,
newchild
;
FTNODE
newparent
,
newchild
;
toku_pin_ftnode
_with_dep_nodes
(
ft
,
parent_blocknum
,
parent_fullhash
,
&
bfe
,
PL_WRITE_CHEAP
,
0
,
nullptr
,
&
newparent
,
true
);
toku_pin_ftnode
(
ft
,
parent_blocknum
,
parent_fullhash
,
&
bfe
,
PL_WRITE_CHEAP
,
&
newparent
,
true
);
if
(
newparent
->
height
!=
parent_height
||
childnum
>=
newparent
->
n_children
)
{
if
(
newparent
->
height
!=
parent_height
||
childnum
>=
newparent
->
n_children
)
{
// looks like this is the root and it got merged, let's just start over (like in the split case above)
// looks like this is the root and it got merged, let's just start over (like in the split case above)
toku_unpin_ftnode_read_only
(
ft
,
newparent
);
toku_unpin_ftnode_read_only
(
ft
,
newparent
);
...
@@ -2886,7 +2884,7 @@ static void inject_message_at_this_blocknum(FT ft, CACHEKEY cachekey, uint32_t f
...
@@ -2886,7 +2884,7 @@ static void inject_message_at_this_blocknum(FT ft, CACHEKEY cachekey, uint32_t f
FTNODE
node
;
FTNODE
node
;
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_full_read
(
&
bfe
,
ft
);
fill_bfe_for_full_read
(
&
bfe
,
ft
);
toku_pin_ftnode
_with_dep_nodes
(
ft
,
cachekey
,
fullhash
,
&
bfe
,
PL_WRITE_CHEAP
,
0
,
NULL
,
&
node
,
true
);
toku_pin_ftnode
(
ft
,
cachekey
,
fullhash
,
&
bfe
,
PL_WRITE_CHEAP
,
&
node
,
true
);
toku_assert_entire_node_in_memory
(
node
);
toku_assert_entire_node_in_memory
(
node
);
paranoid_invariant
(
node
->
fullhash
==
fullhash
);
paranoid_invariant
(
node
->
fullhash
==
fullhash
);
ft_verify_flags
(
ft
,
node
);
ft_verify_flags
(
ft
,
node
);
...
@@ -3009,11 +3007,11 @@ static void push_something_in_subtree(
...
@@ -3009,11 +3007,11 @@ static void push_something_in_subtree(
if
(
lock_type
==
PL_WRITE_CHEAP
)
{
if
(
lock_type
==
PL_WRITE_CHEAP
)
{
// We intend to take the write lock for message injection
// We intend to take the write lock for message injection
toku
::
context
inject_ctx
(
CTX_MESSAGE_INJECTION
);
toku
::
context
inject_ctx
(
CTX_MESSAGE_INJECTION
);
toku_pin_ftnode
_with_dep_nodes
(
ft
,
child_blocknum
,
child_fullhash
,
&
bfe
,
lock_type
,
0
,
nullptr
,
&
child
,
true
);
toku_pin_ftnode
(
ft
,
child_blocknum
,
child_fullhash
,
&
bfe
,
lock_type
,
&
child
,
true
);
}
else
{
}
else
{
// We're going to keep promoting
// We're going to keep promoting
toku
::
context
promo_ctx
(
CTX_PROMO
);
toku
::
context
promo_ctx
(
CTX_PROMO
);
toku_pin_ftnode
_with_dep_nodes
(
ft
,
child_blocknum
,
child_fullhash
,
&
bfe
,
lock_type
,
0
,
nullptr
,
&
child
,
true
);
toku_pin_ftnode
(
ft
,
child_blocknum
,
child_fullhash
,
&
bfe
,
lock_type
,
&
child
,
true
);
}
}
}
else
{
}
else
{
r
=
toku_maybe_pin_ftnode_clean
(
ft
,
child_blocknum
,
child_fullhash
,
lock_type
,
&
child
);
r
=
toku_maybe_pin_ftnode_clean
(
ft
,
child_blocknum
,
child_fullhash
,
lock_type
,
&
child
);
...
@@ -3046,7 +3044,7 @@ static void push_something_in_subtree(
...
@@ -3046,7 +3044,7 @@ static void push_something_in_subtree(
FTNODE
newparent
;
FTNODE
newparent
;
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_full_read
(
&
bfe
,
ft
);
// should be fully in memory, we just split it
fill_bfe_for_full_read
(
&
bfe
,
ft
);
// should be fully in memory, we just split it
toku_pin_ftnode
_with_dep_nodes
(
ft
,
subtree_root_blocknum
,
subtree_root_fullhash
,
&
bfe
,
PL_READ
,
0
,
nullptr
,
&
newparent
,
true
);
toku_pin_ftnode
(
ft
,
subtree_root_blocknum
,
subtree_root_fullhash
,
&
bfe
,
PL_READ
,
&
newparent
,
true
);
push_something_in_subtree
(
ft
,
newparent
,
-
1
,
msg
,
flow_deltas
,
gc_info
,
depth
,
loc
,
true
);
push_something_in_subtree
(
ft
,
newparent
,
-
1
,
msg
,
flow_deltas
,
gc_info
,
depth
,
loc
,
true
);
return
;
return
;
}
}
...
@@ -3143,7 +3141,7 @@ void toku_ft_root_put_msg(
...
@@ -3143,7 +3141,7 @@ void toku_ft_root_put_msg(
// and jump back to here.
// and jump back to here.
change_lock_type:
change_lock_type:
// get the root node
// get the root node
toku_pin_ftnode
_with_dep_nodes
(
ft
,
root_key
,
fullhash
,
&
bfe
,
lock_type
,
0
,
NULL
,
&
node
,
true
);
toku_pin_ftnode
(
ft
,
root_key
,
fullhash
,
&
bfe
,
lock_type
,
&
node
,
true
);
toku_assert_entire_node_in_memory
(
node
);
toku_assert_entire_node_in_memory
(
node
);
paranoid_invariant
(
node
->
fullhash
==
fullhash
);
paranoid_invariant
(
node
->
fullhash
==
fullhash
);
ft_verify_flags
(
ft
,
node
);
ft_verify_flags
(
ft
,
node
);
...
@@ -5466,14 +5464,12 @@ toku_ft_search (FT_HANDLE brt, ft_search_t *search, FT_GET_CALLBACK_FUNCTION get
...
@@ -5466,14 +5464,12 @@ toku_ft_search (FT_HANDLE brt, ft_search_t *search, FT_GET_CALLBACK_FUNCTION get
uint32_t
fullhash
;
uint32_t
fullhash
;
CACHEKEY
root_key
;
CACHEKEY
root_key
;
toku_calculate_root_offset_pointer
(
ft
,
&
root_key
,
&
fullhash
);
toku_calculate_root_offset_pointer
(
ft
,
&
root_key
,
&
fullhash
);
toku_pin_ftnode
_with_dep_nodes
(
toku_pin_ftnode
(
ft
,
ft
,
root_key
,
root_key
,
fullhash
,
fullhash
,
&
bfe
,
&
bfe
,
PL_READ
,
// may_modify_node set to false, because root cannot change during search
PL_READ
,
// may_modify_node set to false, because root cannot change during search
0
,
NULL
,
&
node
,
&
node
,
true
true
);
);
...
@@ -6089,14 +6085,12 @@ void toku_ft_keysrange(FT_HANDLE brt, DBT* key_left, DBT* key_right, uint64_t *l
...
@@ -6089,14 +6085,12 @@ void toku_ft_keysrange(FT_HANDLE brt, DBT* key_left, DBT* key_right, uint64_t *l
uint32_t
fullhash
;
uint32_t
fullhash
;
CACHEKEY
root_key
;
CACHEKEY
root_key
;
toku_calculate_root_offset_pointer
(
brt
->
ft
,
&
root_key
,
&
fullhash
);
toku_calculate_root_offset_pointer
(
brt
->
ft
,
&
root_key
,
&
fullhash
);
toku_pin_ftnode
_with_dep_nodes
(
toku_pin_ftnode
(
brt
->
ft
,
brt
->
ft
,
root_key
,
root_key
,
fullhash
,
fullhash
,
&
match_bfe
,
&
match_bfe
,
PL_READ
,
// may_modify_node, cannot change root during keyrange
PL_READ
,
// may_modify_node, cannot change root during keyrange
0
,
NULL
,
&
node
,
&
node
,
true
true
);
);
...
@@ -6308,7 +6302,7 @@ int toku_ft_get_key_after_bytes(FT_HANDLE ft_h, const DBT *start_key, uint64_t s
...
@@ -6308,7 +6302,7 @@ int toku_ft_get_key_after_bytes(FT_HANDLE ft_h, const DBT *start_key, uint64_t s
uint32_t
fullhash
;
uint32_t
fullhash
;
CACHEKEY
root_key
;
CACHEKEY
root_key
;
toku_calculate_root_offset_pointer
(
ft
,
&
root_key
,
&
fullhash
);
toku_calculate_root_offset_pointer
(
ft
,
&
root_key
,
&
fullhash
);
toku_pin_ftnode
_with_dep_nodes
(
ft
,
root_key
,
fullhash
,
&
bfe
,
PL_READ
,
0
,
nullptr
,
&
root
,
true
);
toku_pin_ftnode
(
ft
,
root_key
,
fullhash
,
&
bfe
,
PL_READ
,
&
root
,
true
);
}
}
struct
unlock_ftnode_extra
unlock_extra
=
{
ft_h
,
root
,
false
};
struct
unlock_ftnode_extra
unlock_extra
=
{
ft_h
,
root
,
false
};
struct
unlockers
unlockers
=
{
true
,
unlock_ftnode_fun
,
(
void
*
)
&
unlock_extra
,
(
UNLOCKERS
)
nullptr
};
struct
unlockers
unlockers
=
{
true
,
unlock_ftnode_fun
,
(
void
*
)
&
unlock_extra
,
(
UNLOCKERS
)
nullptr
};
...
@@ -6366,14 +6360,12 @@ toku_dump_ftnode (FILE *file, FT_HANDLE brt, BLOCKNUM blocknum, int depth, const
...
@@ -6366,14 +6360,12 @@ toku_dump_ftnode (FILE *file, FT_HANDLE brt, BLOCKNUM blocknum, int depth, const
uint32_t
fullhash
=
toku_cachetable_hash
(
brt
->
ft
->
cf
,
blocknum
);
uint32_t
fullhash
=
toku_cachetable_hash
(
brt
->
ft
->
cf
,
blocknum
);
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_full_read
(
&
bfe
,
brt
->
ft
);
fill_bfe_for_full_read
(
&
bfe
,
brt
->
ft
);
toku_pin_ftnode
_with_dep_nodes
(
toku_pin_ftnode
(
brt
->
ft
,
brt
->
ft
,
blocknum
,
blocknum
,
fullhash
,
fullhash
,
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
NULL
,
&
node
,
&
node
,
true
true
);
);
...
@@ -6567,14 +6559,12 @@ static bool is_empty_fast_iter (FT_HANDLE brt, FTNODE node) {
...
@@ -6567,14 +6559,12 @@ static bool is_empty_fast_iter (FT_HANDLE brt, FTNODE node) {
fill_bfe_for_full_read
(
&
bfe
,
brt
->
ft
);
fill_bfe_for_full_read
(
&
bfe
,
brt
->
ft
);
// don't need to pass in dependent nodes as we are not
// don't need to pass in dependent nodes as we are not
// modifying nodes we are pinning
// modifying nodes we are pinning
toku_pin_ftnode
_with_dep_nodes
(
toku_pin_ftnode
(
brt
->
ft
,
brt
->
ft
,
childblocknum
,
childblocknum
,
fullhash
,
fullhash
,
&
bfe
,
&
bfe
,
PL_READ
,
// may_modify_node set to false, as nodes not modified
PL_READ
,
// may_modify_node set to false, as nodes not modified
0
,
NULL
,
&
childnode
,
&
childnode
,
true
true
);
);
...
@@ -6606,14 +6596,12 @@ bool toku_ft_is_empty_fast (FT_HANDLE brt)
...
@@ -6606,14 +6596,12 @@ bool toku_ft_is_empty_fast (FT_HANDLE brt)
toku_calculate_root_offset_pointer
(
brt
->
ft
,
&
root_key
,
&
fullhash
);
toku_calculate_root_offset_pointer
(
brt
->
ft
,
&
root_key
,
&
fullhash
);
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_full_read
(
&
bfe
,
brt
->
ft
);
fill_bfe_for_full_read
(
&
bfe
,
brt
->
ft
);
toku_pin_ftnode
_with_dep_nodes
(
toku_pin_ftnode
(
brt
->
ft
,
brt
->
ft
,
root_key
,
root_key
,
fullhash
,
fullhash
,
&
bfe
,
&
bfe
,
PL_READ
,
// may_modify_node set to false, node does not change
PL_READ
,
// may_modify_node set to false, node does not change
0
,
NULL
,
&
node
,
&
node
,
true
true
);
);
...
...
ft/ft-test-helpers.cc
View file @
433e2bab
...
@@ -254,14 +254,12 @@ toku_pin_node_with_min_bfe(FTNODE* node, BLOCKNUM b, FT_HANDLE t)
...
@@ -254,14 +254,12 @@ toku_pin_node_with_min_bfe(FTNODE* node, BLOCKNUM b, FT_HANDLE t)
{
{
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_min_read
(
&
bfe
,
t
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
t
->
ft
);
toku_pin_ftnode
_with_dep_nodes
(
toku_pin_ftnode
(
t
->
ft
,
t
->
ft
,
b
,
b
,
toku_cachetable_hash
(
t
->
ft
->
cf
,
b
),
toku_cachetable_hash
(
t
->
ft
->
cf
,
b
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
NULL
,
node
,
node
,
true
true
);
);
...
...
ft/ft-verify.cc
View file @
433e2bab
...
@@ -297,14 +297,12 @@ toku_get_node_for_verify(
...
@@ -297,14 +297,12 @@ toku_get_node_for_verify(
uint32_t
fullhash
=
toku_cachetable_hash
(
brt
->
ft
->
cf
,
blocknum
);
uint32_t
fullhash
=
toku_cachetable_hash
(
brt
->
ft
->
cf
,
blocknum
);
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_full_read
(
&
bfe
,
brt
->
ft
);
fill_bfe_for_full_read
(
&
bfe
,
brt
->
ft
);
toku_pin_ftnode
_with_dep_nodes
(
toku_pin_ftnode
(
brt
->
ft
,
brt
->
ft
,
blocknum
,
blocknum
,
fullhash
,
fullhash
,
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
// may_modify_node
PL_WRITE_EXPENSIVE
,
// may_modify_node
0
,
NULL
,
nodep
,
nodep
,
false
false
);
);
...
...
ft/tests/test-checkpoint-during-flush.cc
View file @
433e2bab
...
@@ -230,15 +230,14 @@ doit (bool after_child_pin) {
...
@@ -230,15 +230,14 @@ doit (bool after_child_pin) {
FTNODE
node
=
NULL
;
FTNODE
node
=
NULL
;
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_min_read
(
&
bfe
,
t
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
t
->
ft
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
t
->
ft
,
t
->
ft
,
node_root
,
node_root
,
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
height
==
1
);
assert
(
node
->
height
==
1
);
assert
(
node
->
n_children
==
1
);
assert
(
node
->
n_children
==
1
);
...
@@ -249,15 +248,14 @@ doit (bool after_child_pin) {
...
@@ -249,15 +248,14 @@ doit (bool after_child_pin) {
assert
(
checkpoint_callback_called
);
assert
(
checkpoint_callback_called
);
// now let's pin the root again and make sure it is flushed
// now let's pin the root again and make sure it is flushed
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
t
->
ft
,
t
->
ft
,
node_root
,
node_root
,
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
height
==
1
);
assert
(
node
->
height
==
1
);
assert
(
node
->
n_children
==
1
);
assert
(
node
->
n_children
==
1
);
...
@@ -286,15 +284,14 @@ doit (bool after_child_pin) {
...
@@ -286,15 +284,14 @@ doit (bool after_child_pin) {
// now pin the root, verify that we have a message in there, and that it is clean
// now pin the root, verify that we have a message in there, and that it is clean
//
//
fill_bfe_for_full_read
(
&
bfe
,
c_ft
->
ft
);
fill_bfe_for_full_read
(
&
bfe
,
c_ft
->
ft
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
c_ft
->
ft
,
c_ft
->
ft
,
node_root
,
node_root
,
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
node_root
),
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
node_root
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
height
==
1
);
assert
(
node
->
height
==
1
);
assert
(
!
node
->
dirty
);
assert
(
!
node
->
dirty
);
...
@@ -307,15 +304,14 @@ doit (bool after_child_pin) {
...
@@ -307,15 +304,14 @@ doit (bool after_child_pin) {
}
}
toku_unpin_ftnode
(
c_ft
->
ft
,
node
);
toku_unpin_ftnode
(
c_ft
->
ft
,
node
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
c_ft
->
ft
,
c_ft
->
ft
,
node_leaf
,
node_leaf
,
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
node_root
),
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
node_root
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
height
==
0
);
assert
(
node
->
height
==
0
);
assert
(
!
node
->
dirty
);
assert
(
!
node
->
dirty
);
...
...
ft/tests/test-checkpoint-during-merge.cc
View file @
433e2bab
...
@@ -248,7 +248,7 @@ doit (int state) {
...
@@ -248,7 +248,7 @@ doit (int state) {
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_min_read
(
&
bfe
,
t
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
t
->
ft
);
toku_pin_ftnode_with_dep_
pair
s
(
toku_pin_ftnode_with_dep_
node
s
(
t
->
ft
,
t
->
ft
,
node_root
,
node_root
,
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
...
@@ -267,7 +267,7 @@ doit (int state) {
...
@@ -267,7 +267,7 @@ doit (int state) {
assert
(
checkpoint_callback_called
);
assert
(
checkpoint_callback_called
);
// now let's pin the root again and make sure it is has merged
// now let's pin the root again and make sure it is has merged
toku_pin_ftnode_with_dep_
pair
s
(
toku_pin_ftnode_with_dep_
node
s
(
t
->
ft
,
t
->
ft
,
node_root
,
node_root
,
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
...
@@ -307,7 +307,7 @@ doit (int state) {
...
@@ -307,7 +307,7 @@ doit (int state) {
// now pin the root, verify that the state is what we expect
// now pin the root, verify that the state is what we expect
//
//
fill_bfe_for_full_read
(
&
bfe
,
c_ft
->
ft
);
fill_bfe_for_full_read
(
&
bfe
,
c_ft
->
ft
);
toku_pin_ftnode_with_dep_
pair
s
(
toku_pin_ftnode_with_dep_
node
s
(
c_ft
->
ft
,
c_ft
->
ft
,
node_root
,
node_root
,
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
node_root
),
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
node_root
),
...
@@ -338,7 +338,7 @@ doit (int state) {
...
@@ -338,7 +338,7 @@ doit (int state) {
// now let's verify the leaves are what we expect
// now let's verify the leaves are what we expect
if
(
state
==
flt_flush_before_merge
||
state
==
flt_flush_before_pin_second_node_for_merge
)
{
if
(
state
==
flt_flush_before_merge
||
state
==
flt_flush_before_pin_second_node_for_merge
)
{
toku_pin_ftnode_with_dep_
pair
s
(
toku_pin_ftnode_with_dep_
node
s
(
c_ft
->
ft
,
c_ft
->
ft
,
left_child
,
left_child
,
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
left_child
),
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
left_child
),
...
@@ -355,7 +355,7 @@ doit (int state) {
...
@@ -355,7 +355,7 @@ doit (int state) {
assert
(
BLB_DATA
(
node
,
0
)
->
omt_size
()
==
1
);
assert
(
BLB_DATA
(
node
,
0
)
->
omt_size
()
==
1
);
toku_unpin_ftnode
(
c_ft
->
ft
,
node
);
toku_unpin_ftnode
(
c_ft
->
ft
,
node
);
toku_pin_ftnode_with_dep_
pair
s
(
toku_pin_ftnode_with_dep_
node
s
(
c_ft
->
ft
,
c_ft
->
ft
,
right_child
,
right_child
,
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
right_child
),
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
right_child
),
...
@@ -373,7 +373,7 @@ doit (int state) {
...
@@ -373,7 +373,7 @@ doit (int state) {
toku_unpin_ftnode
(
c_ft
->
ft
,
node
);
toku_unpin_ftnode
(
c_ft
->
ft
,
node
);
}
}
else
if
(
state
==
ft_flush_aflter_merge
||
state
==
flt_flush_before_unpin_remove
)
{
else
if
(
state
==
ft_flush_aflter_merge
||
state
==
flt_flush_before_unpin_remove
)
{
toku_pin_ftnode_with_dep_
pair
s
(
toku_pin_ftnode_with_dep_
node
s
(
c_ft
->
ft
,
c_ft
->
ft
,
left_child
,
left_child
,
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
left_child
),
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
left_child
),
...
...
ft/tests/test-checkpoint-during-rebalance.cc
View file @
433e2bab
...
@@ -268,14 +268,12 @@ doit (int state) {
...
@@ -268,14 +268,12 @@ doit (int state) {
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_min_read
(
&
bfe
,
t
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
t
->
ft
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
t
->
ft
,
t
->
ft
,
node_root
,
node_root
,
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
NULL
,
&
node
,
&
node
,
true
true
);
);
...
@@ -287,14 +285,12 @@ doit (int state) {
...
@@ -287,14 +285,12 @@ doit (int state) {
assert
(
checkpoint_callback_called
);
assert
(
checkpoint_callback_called
);
// now let's pin the root again and make sure it is has rebalanced
// now let's pin the root again and make sure it is has rebalanced
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
t
->
ft
,
t
->
ft
,
node_root
,
node_root
,
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
NULL
,
&
node
,
&
node
,
true
true
);
);
...
@@ -327,15 +323,14 @@ doit (int state) {
...
@@ -327,15 +323,14 @@ doit (int state) {
// now pin the root, verify that the state is what we expect
// now pin the root, verify that the state is what we expect
//
//
fill_bfe_for_full_read
(
&
bfe
,
c_ft
->
ft
);
fill_bfe_for_full_read
(
&
bfe
,
c_ft
->
ft
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
c_ft
->
ft
,
c_ft
->
ft
,
node_root
,
node_root
,
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
node_root
),
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
node_root
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
height
==
1
);
assert
(
node
->
height
==
1
);
assert
(
!
node
->
dirty
);
assert
(
!
node
->
dirty
);
...
@@ -348,15 +343,14 @@ doit (int state) {
...
@@ -348,15 +343,14 @@ doit (int state) {
toku_unpin_ftnode
(
c_ft
->
ft
,
node
);
toku_unpin_ftnode
(
c_ft
->
ft
,
node
);
// now let's verify the leaves are what we expect
// now let's verify the leaves are what we expect
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
c_ft
->
ft
,
c_ft
->
ft
,
left_child
,
left_child
,
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
left_child
),
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
left_child
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
height
==
0
);
assert
(
node
->
height
==
0
);
assert
(
!
node
->
dirty
);
assert
(
!
node
->
dirty
);
...
@@ -364,15 +358,14 @@ doit (int state) {
...
@@ -364,15 +358,14 @@ doit (int state) {
assert
(
BLB_DATA
(
node
,
0
)
->
omt_size
()
==
2
);
assert
(
BLB_DATA
(
node
,
0
)
->
omt_size
()
==
2
);
toku_unpin_ftnode
(
c_ft
->
ft
,
node
);
toku_unpin_ftnode
(
c_ft
->
ft
,
node
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
c_ft
->
ft
,
c_ft
->
ft
,
right_child
,
right_child
,
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
right_child
),
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
right_child
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
height
==
0
);
assert
(
node
->
height
==
0
);
assert
(
!
node
->
dirty
);
assert
(
!
node
->
dirty
);
...
...
ft/tests/test-checkpoint-during-split.cc
View file @
433e2bab
...
@@ -244,15 +244,14 @@ doit (bool after_split) {
...
@@ -244,15 +244,14 @@ doit (bool after_split) {
FTNODE
node
=
NULL
;
FTNODE
node
=
NULL
;
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_min_read
(
&
bfe
,
t
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
t
->
ft
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
t
->
ft
,
t
->
ft
,
node_root
,
node_root
,
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
height
==
1
);
assert
(
node
->
height
==
1
);
assert
(
node
->
n_children
==
1
);
assert
(
node
->
n_children
==
1
);
...
@@ -262,15 +261,14 @@ doit (bool after_split) {
...
@@ -262,15 +261,14 @@ doit (bool after_split) {
assert
(
checkpoint_callback_called
);
assert
(
checkpoint_callback_called
);
// now let's pin the root again and make sure it is has split
// now let's pin the root again and make sure it is has split
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
t
->
ft
,
t
->
ft
,
node_root
,
node_root
,
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
height
==
1
);
assert
(
node
->
height
==
1
);
assert
(
node
->
n_children
==
2
);
assert
(
node
->
n_children
==
2
);
...
@@ -301,15 +299,14 @@ doit (bool after_split) {
...
@@ -301,15 +299,14 @@ doit (bool after_split) {
// now pin the root, verify that we have a message in there, and that it is clean
// now pin the root, verify that we have a message in there, and that it is clean
//
//
fill_bfe_for_full_read
(
&
bfe
,
c_ft
->
ft
);
fill_bfe_for_full_read
(
&
bfe
,
c_ft
->
ft
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
c_ft
->
ft
,
c_ft
->
ft
,
node_root
,
node_root
,
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
node_root
),
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
node_root
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
height
==
1
);
assert
(
node
->
height
==
1
);
assert
(
!
node
->
dirty
);
assert
(
!
node
->
dirty
);
...
@@ -329,15 +326,14 @@ doit (bool after_split) {
...
@@ -329,15 +326,14 @@ doit (bool after_split) {
// now let's verify the leaves are what we expect
// now let's verify the leaves are what we expect
if
(
after_split
)
{
if
(
after_split
)
{
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
c_ft
->
ft
,
c_ft
->
ft
,
left_child
,
left_child
,
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
left_child
),
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
left_child
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
height
==
0
);
assert
(
node
->
height
==
0
);
assert
(
!
node
->
dirty
);
assert
(
!
node
->
dirty
);
...
@@ -345,15 +341,14 @@ doit (bool after_split) {
...
@@ -345,15 +341,14 @@ doit (bool after_split) {
assert
(
BLB_DATA
(
node
,
0
)
->
omt_size
()
==
1
);
assert
(
BLB_DATA
(
node
,
0
)
->
omt_size
()
==
1
);
toku_unpin_ftnode
(
c_ft
->
ft
,
node
);
toku_unpin_ftnode
(
c_ft
->
ft
,
node
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
c_ft
->
ft
,
c_ft
->
ft
,
right_child
,
right_child
,
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
right_child
),
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
right_child
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
height
==
0
);
assert
(
node
->
height
==
0
);
assert
(
!
node
->
dirty
);
assert
(
!
node
->
dirty
);
...
@@ -362,15 +357,14 @@ doit (bool after_split) {
...
@@ -362,15 +357,14 @@ doit (bool after_split) {
toku_unpin_ftnode
(
c_ft
->
ft
,
node
);
toku_unpin_ftnode
(
c_ft
->
ft
,
node
);
}
}
else
{
else
{
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
c_ft
->
ft
,
c_ft
->
ft
,
left_child
,
left_child
,
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
left_child
),
toku_cachetable_hash
(
c_ft
->
ft
->
cf
,
left_child
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
height
==
0
);
assert
(
node
->
height
==
0
);
assert
(
!
node
->
dirty
);
assert
(
!
node
->
dirty
);
...
...
ft/tests/test-dirty-flushes-on-cleaner.cc
View file @
433e2bab
...
@@ -240,7 +240,7 @@ doit (void) {
...
@@ -240,7 +240,7 @@ doit (void) {
FTNODE
node
=
NULL
;
FTNODE
node
=
NULL
;
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
toku_pin_ftnode_with_dep_
pair
s
(
toku_pin_ftnode_with_dep_
node
s
(
brt
->
ft
,
brt
->
ft
,
node_leaf
,
node_leaf
,
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_leaf
),
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_leaf
),
...
@@ -270,7 +270,7 @@ doit (void) {
...
@@ -270,7 +270,7 @@ doit (void) {
// on disk
// on disk
//
//
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
toku_pin_ftnode_with_dep_
pair
s
(
toku_pin_ftnode_with_dep_
node
s
(
brt
->
ft
,
brt
->
ft
,
node_leaf
,
node_leaf
,
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_leaf
),
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_leaf
),
...
@@ -291,7 +291,7 @@ doit (void) {
...
@@ -291,7 +291,7 @@ doit (void) {
// now let us induce a clean on the internal node
// now let us induce a clean on the internal node
//
//
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
toku_pin_ftnode_with_dep_
pair
s
(
toku_pin_ftnode_with_dep_
node
s
(
brt
->
ft
,
brt
->
ft
,
node_internal
,
node_internal
,
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_internal
),
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_internal
),
...
@@ -316,7 +316,7 @@ doit (void) {
...
@@ -316,7 +316,7 @@ doit (void) {
// verify that node_internal's buffer is empty
// verify that node_internal's buffer is empty
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
toku_pin_ftnode_with_dep_
pair
s
(
toku_pin_ftnode_with_dep_
node
s
(
brt
->
ft
,
brt
->
ft
,
node_internal
,
node_internal
,
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_internal
),
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_internal
),
...
...
ft/tests/test-flushes-on-cleaner.cc
View file @
433e2bab
...
@@ -246,15 +246,14 @@ doit (bool keep_other_bn_in_memory) {
...
@@ -246,15 +246,14 @@ doit (bool keep_other_bn_in_memory) {
FTNODE
node
=
NULL
;
FTNODE
node
=
NULL
;
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
brt
->
ft
,
brt
->
ft
,
node_leaf
,
node_leaf
,
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_leaf
),
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_leaf
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
!
node
->
dirty
);
assert
(
!
node
->
dirty
);
assert
(
node
->
n_children
==
2
);
assert
(
node
->
n_children
==
2
);
...
@@ -293,15 +292,14 @@ doit (bool keep_other_bn_in_memory) {
...
@@ -293,15 +292,14 @@ doit (bool keep_other_bn_in_memory) {
//
//
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
}
}
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
brt
->
ft
,
brt
->
ft
,
node_leaf
,
node_leaf
,
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_leaf
),
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_leaf
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
!
node
->
dirty
);
assert
(
!
node
->
dirty
);
assert
(
node
->
n_children
==
2
);
assert
(
node
->
n_children
==
2
);
...
@@ -318,15 +316,14 @@ doit (bool keep_other_bn_in_memory) {
...
@@ -318,15 +316,14 @@ doit (bool keep_other_bn_in_memory) {
// now let us induce a clean on the internal node
// now let us induce a clean on the internal node
//
//
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
brt
->
ft
,
brt
->
ft
,
node_internal
,
node_internal
,
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_internal
),
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_internal
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
!
node
->
dirty
);
assert
(
!
node
->
dirty
);
...
@@ -342,15 +339,14 @@ doit (bool keep_other_bn_in_memory) {
...
@@ -342,15 +339,14 @@ doit (bool keep_other_bn_in_memory) {
// verify that node_internal's buffer is empty
// verify that node_internal's buffer is empty
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
brt
->
ft
,
brt
->
ft
,
node_internal
,
node_internal
,
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_internal
),
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_internal
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
// check that buffers are empty
// check that buffers are empty
assert
(
toku_bnc_nbytesinbuf
(
BNC
(
node
,
0
))
==
0
);
assert
(
toku_bnc_nbytesinbuf
(
BNC
(
node
,
0
))
==
0
);
...
...
ft/tests/test-hot-with-bounds.cc
View file @
433e2bab
...
@@ -183,15 +183,14 @@ doit (void) {
...
@@ -183,15 +183,14 @@ doit (void) {
FTNODE
node
=
NULL
;
FTNODE
node
=
NULL
;
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_min_read
(
&
bfe
,
t
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
t
->
ft
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
t
->
ft
,
t
->
ft
,
node_root
,
node_root
,
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
height
==
1
);
assert
(
node
->
height
==
1
);
assert
(
node
->
n_children
==
3
);
assert
(
node
->
n_children
==
3
);
...
@@ -213,15 +212,14 @@ doit (void) {
...
@@ -213,15 +212,14 @@ doit (void) {
// only the middle buffer, let's verify this.
// only the middle buffer, let's verify this.
node
=
NULL
;
node
=
NULL
;
fill_bfe_for_min_read
(
&
bfe
,
t
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
t
->
ft
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
t
->
ft
,
t
->
ft
,
node_root
,
node_root
,
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_root
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
height
==
1
);
assert
(
node
->
height
==
1
);
assert
(
node
->
n_children
==
3
);
assert
(
node
->
n_children
==
3
);
...
...
ft/tests/test-merges-on-cleaner.cc
View file @
433e2bab
...
@@ -232,15 +232,14 @@ doit (void) {
...
@@ -232,15 +232,14 @@ doit (void) {
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
brt
->
ft
,
brt
->
ft
,
node_internal
,
node_internal
,
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_internal
),
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_internal
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
n_children
==
2
);
assert
(
node
->
n_children
==
2
);
// we expect that this flushes its buffer, that
// we expect that this flushes its buffer, that
...
@@ -255,15 +254,14 @@ doit (void) {
...
@@ -255,15 +254,14 @@ doit (void) {
// verify that node_internal's buffer is empty
// verify that node_internal's buffer is empty
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
brt
->
ft
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
brt
->
ft
,
brt
->
ft
,
node_internal
,
node_internal
,
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_internal
),
toku_cachetable_hash
(
brt
->
ft
->
cf
,
node_internal
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
// check that merge happened
// check that merge happened
assert
(
node
->
n_children
==
1
);
assert
(
node
->
n_children
==
1
);
...
...
ft/tests/test-oldest-referenced-xid-flush.cc
View file @
433e2bab
...
@@ -169,15 +169,14 @@ static void test_oldest_referenced_xid_gets_propogated(void) {
...
@@ -169,15 +169,14 @@ static void test_oldest_referenced_xid_gets_propogated(void) {
FTNODE
node
=
NULL
;
FTNODE
node
=
NULL
;
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_min_read
(
&
bfe
,
t
->
ft
);
fill_bfe_for_min_read
(
&
bfe
,
t
->
ft
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
t
->
ft
,
t
->
ft
,
child_nonleaf_blocknum
,
child_nonleaf_blocknum
,
toku_cachetable_hash
(
t
->
ft
->
cf
,
child_nonleaf_blocknum
),
toku_cachetable_hash
(
t
->
ft
->
cf
,
child_nonleaf_blocknum
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
height
==
1
);
assert
(
node
->
height
==
1
);
assert
(
node
->
n_children
==
1
);
assert
(
node
->
n_children
==
1
);
...
@@ -186,15 +185,14 @@ static void test_oldest_referenced_xid_gets_propogated(void) {
...
@@ -186,15 +185,14 @@ static void test_oldest_referenced_xid_gets_propogated(void) {
toku_unpin_ftnode
(
t
->
ft
,
node
);
toku_unpin_ftnode
(
t
->
ft
,
node
);
// now verify the root - keep it pinned so we can flush it below
// now verify the root - keep it pinned so we can flush it below
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
t
->
ft
,
t
->
ft
,
root_blocknum
,
root_blocknum
,
toku_cachetable_hash
(
t
->
ft
->
cf
,
root_blocknum
),
toku_cachetable_hash
(
t
->
ft
->
cf
,
root_blocknum
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
height
==
2
);
assert
(
node
->
height
==
2
);
assert
(
node
->
n_children
==
1
);
assert
(
node
->
n_children
==
1
);
...
@@ -222,15 +220,14 @@ static void test_oldest_referenced_xid_gets_propogated(void) {
...
@@ -222,15 +220,14 @@ static void test_oldest_referenced_xid_gets_propogated(void) {
// pin the child, verify that oldest referenced xid was
// pin the child, verify that oldest referenced xid was
// propogated from parent to child during the flush
// propogated from parent to child during the flush
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
t
->
ft
,
t
->
ft
,
child_nonleaf_blocknum
,
child_nonleaf_blocknum
,
toku_cachetable_hash
(
t
->
ft
->
cf
,
child_nonleaf_blocknum
),
toku_cachetable_hash
(
t
->
ft
->
cf
,
child_nonleaf_blocknum
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
oldest_referenced_xid_known
==
flush_xid
);
assert
(
node
->
oldest_referenced_xid_known
==
flush_xid
);
...
...
ft/tests/test4244.cc
View file @
433e2bab
...
@@ -150,15 +150,14 @@ doit (void) {
...
@@ -150,15 +150,14 @@ doit (void) {
FTNODE
node
;
FTNODE
node
;
struct
ftnode_fetch_extra
bfe
;
struct
ftnode_fetch_extra
bfe
;
fill_bfe_for_full_read
(
&
bfe
,
t
->
ft
);
fill_bfe_for_full_read
(
&
bfe
,
t
->
ft
);
toku_pin_ftnode
_with_dep_pairs
(
toku_pin_ftnode
(
t
->
ft
,
t
->
ft
,
node_internal
,
node_internal
,
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_internal
),
toku_cachetable_hash
(
t
->
ft
->
cf
,
node_internal
),
&
bfe
,
&
bfe
,
PL_WRITE_EXPENSIVE
,
PL_WRITE_EXPENSIVE
,
0
,
&
node
,
NULL
,
true
&
node
);
);
assert
(
node
->
n_children
==
1
);
assert
(
node
->
n_children
==
1
);
// simply assert that the buffer is less than 50MB,
// simply assert that the buffer is less than 50MB,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment