Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
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
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
96ed47d1
Commit
96ed47d1
authored
Dec 08, 2023
by
Kent Overstreet
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
bcachefs: bch2_btree_path_traverse() -> btree_path_idx_t
Signed-off-by:
Kent Overstreet
<
kent.overstreet@linux.dev
>
parent
f6363aca
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
31 additions
and
27 deletions
+31
-27
fs/bcachefs/btree_iter.c
fs/bcachefs/btree_iter.c
+18
-15
fs/bcachefs/btree_iter.h
fs/bcachefs/btree_iter.h
+4
-5
fs/bcachefs/btree_update.c
fs/bcachefs/btree_update.c
+3
-3
fs/bcachefs/btree_update_interior.c
fs/bcachefs/btree_update_interior.c
+6
-4
No files found.
fs/bcachefs/btree_iter.c
View file @
96ed47d1
...
@@ -994,16 +994,16 @@ static int bch2_btree_path_traverse_all(struct btree_trans *trans)
...
@@ -994,16 +994,16 @@ static int bch2_btree_path_traverse_all(struct btree_trans *trans)
/* Now, redo traversals in correct order: */
/* Now, redo traversals in correct order: */
i
=
0
;
i
=
0
;
while
(
i
<
trans
->
nr_sorted
)
{
while
(
i
<
trans
->
nr_sorted
)
{
path
=
trans
->
paths
+
trans
->
sorted
[
i
];
btree_path_idx_t
idx
=
trans
->
sorted
[
i
];
/*
/*
* Traversing a path can cause another path to be added at about
* Traversing a path can cause another path to be added at about
* the same position:
* the same position:
*/
*/
if
(
path
->
uptodate
)
{
if
(
trans
->
paths
[
idx
].
uptodate
)
{
__btree_path_get
(
path
,
false
);
__btree_path_get
(
&
trans
->
paths
[
idx
]
,
false
);
ret
=
bch2_btree_path_traverse_one
(
trans
,
path
,
0
,
_THIS_IP_
);
ret
=
bch2_btree_path_traverse_one
(
trans
,
idx
,
0
,
_THIS_IP_
);
__btree_path_put
(
path
,
false
);
__btree_path_put
(
&
trans
->
paths
[
idx
]
,
false
);
if
(
bch2_err_matches
(
ret
,
BCH_ERR_transaction_restart
)
||
if
(
bch2_err_matches
(
ret
,
BCH_ERR_transaction_restart
)
||
bch2_err_matches
(
ret
,
ENOMEM
))
bch2_err_matches
(
ret
,
ENOMEM
))
...
@@ -1108,10 +1108,11 @@ static inline unsigned btree_path_up_until_good_node(struct btree_trans *trans,
...
@@ -1108,10 +1108,11 @@ static inline unsigned btree_path_up_until_good_node(struct btree_trans *trans,
* stashed in the iterator and returned from bch2_trans_exit().
* stashed in the iterator and returned from bch2_trans_exit().
*/
*/
int
bch2_btree_path_traverse_one
(
struct
btree_trans
*
trans
,
int
bch2_btree_path_traverse_one
(
struct
btree_trans
*
trans
,
struct
btree_path
*
path
,
btree_path_idx_t
path_idx
,
unsigned
flags
,
unsigned
flags
,
unsigned
long
trace_ip
)
unsigned
long
trace_ip
)
{
{
struct
btree_path
*
path
=
&
trans
->
paths
[
path_idx
];
unsigned
depth_want
=
path
->
level
;
unsigned
depth_want
=
path
->
level
;
int
ret
=
-
((
int
)
trans
->
restarted
);
int
ret
=
-
((
int
)
trans
->
restarted
);
...
@@ -1135,6 +1136,8 @@ int bch2_btree_path_traverse_one(struct btree_trans *trans,
...
@@ -1135,6 +1136,8 @@ int bch2_btree_path_traverse_one(struct btree_trans *trans,
goto
out
;
goto
out
;
}
}
path
=
&
trans
->
paths
[
path_idx
];
if
(
unlikely
(
path
->
level
>=
BTREE_MAX_DEPTH
))
if
(
unlikely
(
path
->
level
>=
BTREE_MAX_DEPTH
))
goto
out
;
goto
out
;
...
@@ -1665,7 +1668,7 @@ struct bkey_s_c bch2_btree_path_peek_slot(struct btree_path *path, struct bkey *
...
@@ -1665,7 +1668,7 @@ struct bkey_s_c bch2_btree_path_peek_slot(struct btree_path *path, struct bkey *
int
__must_check
int
__must_check
__bch2_btree_iter_traverse
(
struct
btree_iter
*
iter
)
__bch2_btree_iter_traverse
(
struct
btree_iter
*
iter
)
{
{
return
bch2_btree_path_traverse
(
iter
->
trans
,
iter
->
path
,
iter
->
flags
);
return
bch2_btree_path_traverse
(
iter
->
trans
,
iter
->
path
->
idx
,
iter
->
flags
);
}
}
int
__must_check
int
__must_check
...
@@ -1679,7 +1682,7 @@ bch2_btree_iter_traverse(struct btree_iter *iter)
...
@@ -1679,7 +1682,7 @@ bch2_btree_iter_traverse(struct btree_iter *iter)
iter
->
flags
&
BTREE_ITER_INTENT
,
iter
->
flags
&
BTREE_ITER_INTENT
,
btree_iter_ip_allocated
(
iter
));
btree_iter_ip_allocated
(
iter
));
ret
=
bch2_btree_path_traverse
(
trans
,
iter
->
path
,
iter
->
flags
);
ret
=
bch2_btree_path_traverse
(
trans
,
iter
->
path
->
idx
,
iter
->
flags
);
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
...
@@ -1698,7 +1701,7 @@ struct btree *bch2_btree_iter_peek_node(struct btree_iter *iter)
...
@@ -1698,7 +1701,7 @@ struct btree *bch2_btree_iter_peek_node(struct btree_iter *iter)
EBUG_ON
(
iter
->
path
->
cached
);
EBUG_ON
(
iter
->
path
->
cached
);
bch2_btree_iter_verify
(
iter
);
bch2_btree_iter_verify
(
iter
);
ret
=
bch2_btree_path_traverse
(
trans
,
iter
->
path
,
iter
->
flags
);
ret
=
bch2_btree_path_traverse
(
trans
,
iter
->
path
->
idx
,
iter
->
flags
);
if
(
ret
)
if
(
ret
)
goto
err
;
goto
err
;
...
@@ -1783,7 +1786,7 @@ struct btree *bch2_btree_iter_next_node(struct btree_iter *iter)
...
@@ -1783,7 +1786,7 @@ struct btree *bch2_btree_iter_next_node(struct btree_iter *iter)
btree_path_set_level_down
(
trans
,
path
,
iter
->
min_depth
);
btree_path_set_level_down
(
trans
,
path
,
iter
->
min_depth
);
ret
=
bch2_btree_path_traverse
(
trans
,
path
,
iter
->
flags
);
ret
=
bch2_btree_path_traverse
(
trans
,
path
->
idx
,
iter
->
flags
);
if
(
ret
)
if
(
ret
)
goto
err
;
goto
err
;
...
@@ -1937,7 +1940,7 @@ struct bkey_s_c btree_trans_peek_key_cache(struct btree_iter *iter, struct bpos
...
@@ -1937,7 +1940,7 @@ struct bkey_s_c btree_trans_peek_key_cache(struct btree_iter *iter, struct bpos
iter
->
flags
&
BTREE_ITER_INTENT
,
iter
->
flags
&
BTREE_ITER_INTENT
,
btree_iter_ip_allocated
(
iter
));
btree_iter_ip_allocated
(
iter
));
ret
=
bch2_btree_path_traverse
(
trans
,
iter
->
key_cache_path
,
ret
=
bch2_btree_path_traverse
(
trans
,
iter
->
key_cache_path
->
idx
,
iter
->
flags
|
BTREE_ITER_CACHED
)
?:
iter
->
flags
|
BTREE_ITER_CACHED
)
?:
bch2_btree_path_relock
(
trans
,
iter
->
path
,
_THIS_IP_
);
bch2_btree_path_relock
(
trans
,
iter
->
path
,
_THIS_IP_
);
if
(
unlikely
(
ret
))
if
(
unlikely
(
ret
))
...
@@ -1970,7 +1973,7 @@ static struct bkey_s_c __bch2_btree_iter_peek(struct btree_iter *iter, struct bp
...
@@ -1970,7 +1973,7 @@ static struct bkey_s_c __bch2_btree_iter_peek(struct btree_iter *iter, struct bp
iter
->
flags
&
BTREE_ITER_INTENT
,
iter
->
flags
&
BTREE_ITER_INTENT
,
btree_iter_ip_allocated
(
iter
));
btree_iter_ip_allocated
(
iter
));
ret
=
bch2_btree_path_traverse
(
trans
,
iter
->
path
,
iter
->
flags
);
ret
=
bch2_btree_path_traverse
(
trans
,
iter
->
path
->
idx
,
iter
->
flags
);
if
(
unlikely
(
ret
))
{
if
(
unlikely
(
ret
))
{
/* ensure that iter->k is consistent with iter->pos: */
/* ensure that iter->k is consistent with iter->pos: */
bch2_btree_iter_set_pos
(
iter
,
iter
->
pos
);
bch2_btree_iter_set_pos
(
iter
,
iter
->
pos
);
...
@@ -2123,7 +2126,7 @@ struct bkey_s_c bch2_btree_iter_peek_upto(struct btree_iter *iter, struct bpos e
...
@@ -2123,7 +2126,7 @@ struct bkey_s_c bch2_btree_iter_peek_upto(struct btree_iter *iter, struct bpos e
iter
->
update_path
->
idx
,
pos
,
iter
->
update_path
->
idx
,
pos
,
iter
->
flags
&
BTREE_ITER_INTENT
,
iter
->
flags
&
BTREE_ITER_INTENT
,
_THIS_IP_
);
_THIS_IP_
);
ret
=
bch2_btree_path_traverse
(
trans
,
iter
->
update_path
,
iter
->
flags
);
ret
=
bch2_btree_path_traverse
(
trans
,
iter
->
update_path
->
idx
,
iter
->
flags
);
if
(
unlikely
(
ret
))
{
if
(
unlikely
(
ret
))
{
k
=
bkey_s_c_err
(
ret
);
k
=
bkey_s_c_err
(
ret
);
goto
out_no_locked
;
goto
out_no_locked
;
...
@@ -2249,7 +2252,7 @@ struct bkey_s_c bch2_btree_iter_peek_prev(struct btree_iter *iter)
...
@@ -2249,7 +2252,7 @@ struct bkey_s_c bch2_btree_iter_peek_prev(struct btree_iter *iter)
iter
->
flags
&
BTREE_ITER_INTENT
,
iter
->
flags
&
BTREE_ITER_INTENT
,
btree_iter_ip_allocated
(
iter
));
btree_iter_ip_allocated
(
iter
));
ret
=
bch2_btree_path_traverse
(
trans
,
iter
->
path
,
iter
->
flags
);
ret
=
bch2_btree_path_traverse
(
trans
,
iter
->
path
->
idx
,
iter
->
flags
);
if
(
unlikely
(
ret
))
{
if
(
unlikely
(
ret
))
{
/* ensure that iter->k is consistent with iter->pos: */
/* ensure that iter->k is consistent with iter->pos: */
bch2_btree_iter_set_pos
(
iter
,
iter
->
pos
);
bch2_btree_iter_set_pos
(
iter
,
iter
->
pos
);
...
@@ -2382,7 +2385,7 @@ struct bkey_s_c bch2_btree_iter_peek_slot(struct btree_iter *iter)
...
@@ -2382,7 +2385,7 @@ struct bkey_s_c bch2_btree_iter_peek_slot(struct btree_iter *iter)
iter
->
flags
&
BTREE_ITER_INTENT
,
iter
->
flags
&
BTREE_ITER_INTENT
,
btree_iter_ip_allocated
(
iter
));
btree_iter_ip_allocated
(
iter
));
ret
=
bch2_btree_path_traverse
(
trans
,
iter
->
path
,
iter
->
flags
);
ret
=
bch2_btree_path_traverse
(
trans
,
iter
->
path
->
idx
,
iter
->
flags
);
if
(
unlikely
(
ret
))
{
if
(
unlikely
(
ret
))
{
k
=
bkey_s_c_err
(
ret
);
k
=
bkey_s_c_err
(
ret
);
goto
out_no_locked
;
goto
out_no_locked
;
...
...
fs/bcachefs/btree_iter.h
View file @
96ed47d1
...
@@ -189,20 +189,19 @@ bch2_btree_path_set_pos(struct btree_trans *trans,
...
@@ -189,20 +189,19 @@ bch2_btree_path_set_pos(struct btree_trans *trans,
:
path
;
:
path
;
}
}
int
__must_check
bch2_btree_path_traverse_one
(
struct
btree_trans
*
,
struct
btree_path
*
,
int
__must_check
bch2_btree_path_traverse_one
(
struct
btree_trans
*
,
btree_path_idx_t
,
unsigned
,
unsigned
long
);
unsigned
,
unsigned
long
);
static
inline
int
__must_check
bch2_btree_path_traverse
(
struct
btree_trans
*
trans
,
static
inline
int
__must_check
bch2_btree_path_traverse
(
struct
btree_trans
*
trans
,
struct
btree_path
*
path
,
unsigned
flags
)
btree_path_idx_t
path
,
unsigned
flags
)
{
{
if
(
path
->
uptodate
<
BTREE_ITER_NEED_RELOCK
)
if
(
trans
->
paths
[
path
].
uptodate
<
BTREE_ITER_NEED_RELOCK
)
return
0
;
return
0
;
return
bch2_btree_path_traverse_one
(
trans
,
path
,
flags
,
_RET_IP_
);
return
bch2_btree_path_traverse_one
(
trans
,
path
,
flags
,
_RET_IP_
);
}
}
int
__must_check
bch2_btree_path_traverse
(
struct
btree_trans
*
,
struct
btree_path
*
,
unsigned
);
btree_path_idx_t
bch2_path_get
(
struct
btree_trans
*
,
enum
btree_id
,
struct
bpos
,
btree_path_idx_t
bch2_path_get
(
struct
btree_trans
*
,
enum
btree_id
,
struct
bpos
,
unsigned
,
unsigned
,
unsigned
,
unsigned
long
);
unsigned
,
unsigned
,
unsigned
,
unsigned
long
);
struct
bkey_s_c
bch2_btree_path_peek_slot
(
struct
btree_path
*
,
struct
bkey
*
);
struct
bkey_s_c
bch2_btree_path_peek_slot
(
struct
btree_path
*
,
struct
bkey
*
);
...
...
fs/bcachefs/btree_update.c
View file @
96ed47d1
...
@@ -350,7 +350,7 @@ static noinline int flush_new_cached_update(struct btree_trans *trans,
...
@@ -350,7 +350,7 @@ static noinline int flush_new_cached_update(struct btree_trans *trans,
btree_path_idx_t
path_idx
=
btree_path_idx_t
path_idx
=
bch2_path_get
(
trans
,
path
->
btree_id
,
path
->
pos
,
1
,
0
,
bch2_path_get
(
trans
,
path
->
btree_id
,
path
->
pos
,
1
,
0
,
BTREE_ITER_INTENT
,
_THIS_IP_
);
BTREE_ITER_INTENT
,
_THIS_IP_
);
ret
=
bch2_btree_path_traverse
(
trans
,
trans
->
paths
+
path_idx
,
0
);
ret
=
bch2_btree_path_traverse
(
trans
,
path_idx
,
0
);
if
(
ret
)
if
(
ret
)
goto
out
;
goto
out
;
...
@@ -372,7 +372,7 @@ static noinline int flush_new_cached_update(struct btree_trans *trans,
...
@@ -372,7 +372,7 @@ static noinline int flush_new_cached_update(struct btree_trans *trans,
btree_path_set_should_be_locked
(
btree_path
);
btree_path_set_should_be_locked
(
btree_path
);
ret
=
bch2_trans_update_by_path
(
trans
,
btree_path
,
i
->
k
,
flags
,
ip
);
ret
=
bch2_trans_update_by_path
(
trans
,
btree_path
,
i
->
k
,
flags
,
ip
);
out:
out:
bch2_path_put
(
trans
,
btree_path
->
idx
,
true
);
bch2_path_put
(
trans
,
path_
idx
,
true
);
return
ret
;
return
ret
;
}
}
...
@@ -480,7 +480,7 @@ static noinline int bch2_trans_update_get_key_cache(struct btree_trans *trans,
...
@@ -480,7 +480,7 @@ static noinline int bch2_trans_update_get_key_cache(struct btree_trans *trans,
iter
->
flags
&
BTREE_ITER_INTENT
,
iter
->
flags
&
BTREE_ITER_INTENT
,
_THIS_IP_
);
_THIS_IP_
);
ret
=
bch2_btree_path_traverse
(
trans
,
iter
->
key_cache_path
,
ret
=
bch2_btree_path_traverse
(
trans
,
iter
->
key_cache_path
->
idx
,
BTREE_ITER_CACHED
);
BTREE_ITER_CACHED
);
if
(
unlikely
(
ret
))
if
(
unlikely
(
ret
))
return
ret
;
return
ret
;
...
...
fs/bcachefs/btree_update_interior.c
View file @
96ed47d1
...
@@ -1795,12 +1795,14 @@ int __bch2_foreground_maybe_merge(struct btree_trans *trans,
...
@@ -1795,12 +1795,14 @@ int __bch2_foreground_maybe_merge(struct btree_trans *trans,
?
bpos_predecessor
(
b
->
data
->
min_key
)
?
bpos_predecessor
(
b
->
data
->
min_key
)
:
bpos_successor
(
b
->
data
->
max_key
);
:
bpos_successor
(
b
->
data
->
max_key
);
sib_path
=
trans
->
paths
+
bch2_path_get
(
trans
,
path
->
btree_id
,
sib_pos
,
btree_path_idx_t
sib_path_idx
=
bch2_path_get
(
trans
,
path
->
btree_id
,
sib_pos
,
U8_MAX
,
level
,
BTREE_ITER_INTENT
,
_THIS_IP_
);
U8_MAX
,
level
,
BTREE_ITER_INTENT
,
_THIS_IP_
);
ret
=
bch2_btree_path_traverse
(
trans
,
sib_path
,
false
);
ret
=
bch2_btree_path_traverse
(
trans
,
sib_path
_idx
,
false
);
if
(
ret
)
if
(
ret
)
goto
err
;
goto
err
;
sib_path
=
trans
->
paths
+
sib_path_idx
;
btree_path_set_should_be_locked
(
sib_path
);
btree_path_set_should_be_locked
(
sib_path
);
m
=
sib_path
->
l
[
level
].
b
;
m
=
sib_path
->
l
[
level
].
b
;
...
@@ -1927,7 +1929,7 @@ int __bch2_foreground_maybe_merge(struct btree_trans *trans,
...
@@ -1927,7 +1929,7 @@ int __bch2_foreground_maybe_merge(struct btree_trans *trans,
err:
err:
if
(
new_path
)
if
(
new_path
)
bch2_path_put
(
trans
,
new_path
->
idx
,
true
);
bch2_path_put
(
trans
,
new_path
->
idx
,
true
);
bch2_path_put
(
trans
,
sib_path
->
idx
,
true
);
bch2_path_put
(
trans
,
sib_path
_
idx
,
true
);
bch2_trans_verify_locks
(
trans
);
bch2_trans_verify_locks
(
trans
);
return
ret
;
return
ret
;
err_free_update:
err_free_update:
...
...
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