Commit ab158fce authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: Converting to typed bkeys is now allowed for err, null ptrs

Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 95b595a5
...@@ -619,20 +619,20 @@ struct bkey_s_##name { \ ...@@ -619,20 +619,20 @@ struct bkey_s_##name { \
\ \
static inline struct bkey_i_##name *bkey_i_to_##name(struct bkey_i *k) \ static inline struct bkey_i_##name *bkey_i_to_##name(struct bkey_i *k) \
{ \ { \
EBUG_ON(k->k.type != KEY_TYPE_##name); \ EBUG_ON(!IS_ERR_OR_NULL(k) && k->k.type != KEY_TYPE_##name); \
return container_of(&k->k, struct bkey_i_##name, k); \ return container_of(&k->k, struct bkey_i_##name, k); \
} \ } \
\ \
static inline const struct bkey_i_##name * \ static inline const struct bkey_i_##name * \
bkey_i_to_##name##_c(const struct bkey_i *k) \ bkey_i_to_##name##_c(const struct bkey_i *k) \
{ \ { \
EBUG_ON(k->k.type != KEY_TYPE_##name); \ EBUG_ON(!IS_ERR_OR_NULL(k) && k->k.type != KEY_TYPE_##name); \
return container_of(&k->k, struct bkey_i_##name, k); \ return container_of(&k->k, struct bkey_i_##name, k); \
} \ } \
\ \
static inline struct bkey_s_##name bkey_s_to_##name(struct bkey_s k) \ static inline struct bkey_s_##name bkey_s_to_##name(struct bkey_s k) \
{ \ { \
EBUG_ON(k.k->type != KEY_TYPE_##name); \ EBUG_ON(!IS_ERR_OR_NULL(k.k) && k.k->type != KEY_TYPE_##name); \
return (struct bkey_s_##name) { \ return (struct bkey_s_##name) { \
.k = k.k, \ .k = k.k, \
.v = container_of(k.v, struct bch_##name, v), \ .v = container_of(k.v, struct bch_##name, v), \
...@@ -641,7 +641,7 @@ static inline struct bkey_s_##name bkey_s_to_##name(struct bkey_s k) \ ...@@ -641,7 +641,7 @@ static inline struct bkey_s_##name bkey_s_to_##name(struct bkey_s k) \
\ \
static inline struct bkey_s_c_##name bkey_s_c_to_##name(struct bkey_s_c k)\ static inline struct bkey_s_c_##name bkey_s_c_to_##name(struct bkey_s_c k)\
{ \ { \
EBUG_ON(k.k->type != KEY_TYPE_##name); \ EBUG_ON(!IS_ERR_OR_NULL(k.k) && k.k->type != KEY_TYPE_##name); \
return (struct bkey_s_c_##name) { \ return (struct bkey_s_c_##name) { \
.k = k.k, \ .k = k.k, \
.v = container_of(k.v, struct bch_##name, v), \ .v = container_of(k.v, struct bch_##name, v), \
...@@ -667,7 +667,7 @@ name##_i_to_s_c(const struct bkey_i_##name *k) \ ...@@ -667,7 +667,7 @@ name##_i_to_s_c(const struct bkey_i_##name *k) \
\ \
static inline struct bkey_s_##name bkey_i_to_s_##name(struct bkey_i *k) \ static inline struct bkey_s_##name bkey_i_to_s_##name(struct bkey_i *k) \
{ \ { \
EBUG_ON(k->k.type != KEY_TYPE_##name); \ EBUG_ON(!IS_ERR_OR_NULL(k) && k->k.type != KEY_TYPE_##name); \
return (struct bkey_s_##name) { \ return (struct bkey_s_##name) { \
.k = &k->k, \ .k = &k->k, \
.v = container_of(&k->v, struct bch_##name, v), \ .v = container_of(&k->v, struct bch_##name, v), \
...@@ -677,7 +677,7 @@ static inline struct bkey_s_##name bkey_i_to_s_##name(struct bkey_i *k) \ ...@@ -677,7 +677,7 @@ static inline struct bkey_s_##name bkey_i_to_s_##name(struct bkey_i *k) \
static inline struct bkey_s_c_##name \ static inline struct bkey_s_c_##name \
bkey_i_to_s_c_##name(const struct bkey_i *k) \ bkey_i_to_s_c_##name(const struct bkey_i *k) \
{ \ { \
EBUG_ON(k->k.type != KEY_TYPE_##name); \ EBUG_ON(!IS_ERR_OR_NULL(k) && k->k.type != KEY_TYPE_##name); \
return (struct bkey_s_c_##name) { \ return (struct bkey_s_c_##name) { \
.k = &k->k, \ .k = &k->k, \
.v = container_of(&k->v, struct bch_##name, v), \ .v = container_of(&k->v, struct bch_##name, v), \
......
...@@ -6,6 +6,13 @@ ...@@ -6,6 +6,13 @@
#include "btree_types.h" #include "btree_types.h"
#include "trace.h" #include "trace.h"
static inline int __bkey_err(const struct bkey *k)
{
return PTR_ERR_OR_ZERO(k);
}
#define bkey_err(_k) __bkey_err((_k).k)
static inline void __btree_path_get(struct btree_path *path, bool intent) static inline void __btree_path_get(struct btree_path *path, bool intent)
{ {
path->ref++; path->ref++;
...@@ -539,11 +546,6 @@ u32 bch2_trans_begin(struct btree_trans *); ...@@ -539,11 +546,6 @@ u32 bch2_trans_begin(struct btree_trans *);
__for_each_btree_node(_trans, _iter, _btree_id, _start, \ __for_each_btree_node(_trans, _iter, _btree_id, _start, \
0, 0, _flags, _b, _ret) 0, 0, _flags, _b, _ret)
static inline int bkey_err(struct bkey_s_c k)
{
return PTR_ERR_OR_ZERO(k.k);
}
static inline struct bkey_s_c bch2_btree_iter_peek_prev_type(struct btree_iter *iter, static inline struct bkey_s_c bch2_btree_iter_peek_prev_type(struct btree_iter *iter,
unsigned flags) unsigned flags)
{ {
......
...@@ -1122,7 +1122,7 @@ static int inode_backpointer_exists(struct btree_trans *trans, ...@@ -1122,7 +1122,7 @@ static int inode_backpointer_exists(struct btree_trans *trans,
d = dirent_get_by_pos(trans, &iter, d = dirent_get_by_pos(trans, &iter,
SPOS(inode->bi_dir, inode->bi_dir_offset, snapshot)); SPOS(inode->bi_dir, inode->bi_dir_offset, snapshot));
ret = bkey_err(d.s_c); ret = bkey_err(d);
if (ret) if (ret)
return ret == -ENOENT ? 0 : ret; return ret == -ENOENT ? 0 : ret;
......
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