2019-03-08 03:46:10 +03:00
# ifndef _BCACHEFS_BTREE_KEY_CACHE_H
# define _BCACHEFS_BTREE_KEY_CACHE_H
2020-11-20 03:54:40 +03:00
static inline size_t bch2_nr_btree_keys_need_flush ( struct bch_fs * c )
{
size_t nr_dirty = READ_ONCE ( c - > btree_key_cache . nr_dirty ) ;
size_t nr_keys = READ_ONCE ( c - > btree_key_cache . nr_dirty ) ;
2020-11-20 05:40:03 +03:00
size_t max_dirty = 4096 + nr_keys / 2 ;
2020-11-20 03:54:40 +03:00
return max_t ( ssize_t , 0 , nr_dirty - max_dirty ) ;
}
2020-11-20 05:40:03 +03:00
static inline bool bch2_btree_key_cache_must_wait ( struct bch_fs * c )
{
size_t nr_dirty = READ_ONCE ( c - > btree_key_cache . nr_dirty ) ;
size_t nr_keys = READ_ONCE ( c - > btree_key_cache . nr_dirty ) ;
size_t max_dirty = 4096 + ( nr_keys * 3 ) / 4 ;
return nr_dirty > max_dirty ;
}
2019-09-23 02:10:21 +03:00
struct bkey_cached *
bch2_btree_key_cache_find ( struct bch_fs * , enum btree_id , struct bpos ) ;
2019-03-08 03:46:10 +03:00
int bch2_btree_iter_traverse_cached ( struct btree_iter * ) ;
bool bch2_btree_insert_key_cached ( struct btree_trans * ,
struct btree_iter * , struct bkey_i * ) ;
int bch2_btree_key_cache_flush ( struct btree_trans * ,
enum btree_id , struct bpos ) ;
# ifdef CONFIG_BCACHEFS_DEBUG
void bch2_btree_key_cache_verify_clean ( struct btree_trans * ,
enum btree_id , struct bpos ) ;
# else
static inline void
bch2_btree_key_cache_verify_clean ( struct btree_trans * trans ,
enum btree_id id , struct bpos pos ) { }
# endif
void bch2_fs_btree_key_cache_exit ( struct btree_key_cache * ) ;
void bch2_fs_btree_key_cache_init_early ( struct btree_key_cache * ) ;
int bch2_fs_btree_key_cache_init ( struct btree_key_cache * ) ;
2020-06-16 02:53:46 +03:00
void bch2_btree_key_cache_to_text ( struct printbuf * , struct btree_key_cache * ) ;
2020-11-18 22:09:33 +03:00
void bch2_btree_key_cache_exit ( void ) ;
int __init bch2_btree_key_cache_init ( void ) ;
2019-03-08 03:46:10 +03:00
# endif /* _BCACHEFS_BTREE_KEY_CACHE_H */