1 #ifndef _BCACHE_ALLOC_H
2 #define _BCACHE_ALLOC_H
5 #include "alloc_types.h"
13 static inline size_t prios_per_bucket(const struct bch_dev *ca)
15 return (bucket_bytes(ca) - sizeof(struct prio_set)) /
16 sizeof(struct bucket_disk);
19 static inline size_t prio_buckets(const struct bch_dev *ca)
21 return DIV_ROUND_UP((size_t) (ca)->mi.nbuckets, prios_per_bucket(ca));
24 void bch2_dev_group_remove(struct dev_group *, struct bch_dev *);
25 void bch2_dev_group_add(struct dev_group *, struct bch_dev *);
27 int bch2_prio_read(struct bch_dev *);
28 int bch2_prio_write(struct bch_dev *);
30 size_t bch2_bucket_alloc(struct bch_dev *, enum alloc_reserve);
32 void bch2_open_bucket_put(struct bch_fs *, struct open_bucket *);
34 struct open_bucket *bch2_alloc_sectors_start(struct bch_fs *,
40 void bch2_alloc_sectors_append_ptrs(struct bch_fs *, struct bkey_i_extent *,
41 unsigned, struct open_bucket *, unsigned);
42 void bch2_alloc_sectors_done(struct bch_fs *, struct write_point *,
43 struct open_bucket *);
45 struct open_bucket *bch2_alloc_sectors(struct bch_fs *, struct write_point *,
46 struct bkey_i_extent *, unsigned, unsigned,
47 enum alloc_reserve, struct closure *);
49 static inline void bch2_wake_allocator(struct bch_dev *ca)
51 struct task_struct *p;
54 if ((p = ACCESS_ONCE(ca->alloc_thread)))
59 static inline struct bch_dev *dev_group_next(struct dev_group *devs,
62 struct bch_dev *ret = NULL;
64 while (*iter < devs->nr &&
65 !(ret = rcu_dereference_check(devs->d[*iter].dev,
66 lockdep_is_held(&devs->lock))))
72 #define group_for_each_dev(ca, devs, iter) \
74 ((ca) = dev_group_next((devs), &(iter))); \
77 #define open_bucket_for_each_ptr(_ob, _ptr) \
78 for ((_ptr) = (_ob)->ptrs; \
79 (_ptr) < (_ob)->ptrs + (_ob)->nr_ptrs; \
82 void bch2_recalc_capacity(struct bch_fs *);
83 void bch2_dev_allocator_stop(struct bch_dev *);
84 int bch2_dev_allocator_start(struct bch_dev *);
85 void bch2_fs_allocator_init(struct bch_fs *);
87 #endif /* _BCACHE_ALLOC_H */