Linux Audio

Check our new training course

Loading...
Note: File does not exist in v4.10.11.
  1/* SPDX-License-Identifier: GPL-2.0 */
  2#ifndef _BCACHEFS_ALLOC_TYPES_H
  3#define _BCACHEFS_ALLOC_TYPES_H
  4
  5#include <linux/mutex.h>
  6#include <linux/spinlock.h>
  7
  8#include "clock_types.h"
  9#include "fifo.h"
 10
 11struct bucket_alloc_state {
 12	enum {
 13		BTREE_BITMAP_NO,
 14		BTREE_BITMAP_YES,
 15		BTREE_BITMAP_ANY,
 16	}	btree_bitmap;
 17
 18	u64	buckets_seen;
 19	u64	skipped_open;
 20	u64	skipped_need_journal_commit;
 21	u64	skipped_nocow;
 22	u64	skipped_nouse;
 23	u64	skipped_mi_btree_bitmap;
 24};
 25
 26#define BCH_WATERMARKS()		\
 27	x(stripe)			\
 28	x(normal)			\
 29	x(copygc)			\
 30	x(btree)			\
 31	x(btree_copygc)			\
 32	x(reclaim)			\
 33	x(interior_updates)
 34
 35enum bch_watermark {
 36#define x(name)	BCH_WATERMARK_##name,
 37	BCH_WATERMARKS()
 38#undef x
 39	BCH_WATERMARK_NR,
 40};
 41
 42#define BCH_WATERMARK_BITS	3
 43#define BCH_WATERMARK_MASK	~(~0U << BCH_WATERMARK_BITS)
 44
 45#define OPEN_BUCKETS_COUNT	1024
 46
 47#define WRITE_POINT_HASH_NR	32
 48#define WRITE_POINT_MAX		32
 49
 50/*
 51 * 0 is never a valid open_bucket_idx_t:
 52 */
 53typedef u16			open_bucket_idx_t;
 54
 55struct open_bucket {
 56	spinlock_t		lock;
 57	atomic_t		pin;
 58	open_bucket_idx_t	freelist;
 59	open_bucket_idx_t	hash;
 60
 61	/*
 62	 * When an open bucket has an ec_stripe attached, this is the index of
 63	 * the block in the stripe this open_bucket corresponds to:
 64	 */
 65	u8			ec_idx;
 66	enum bch_data_type	data_type:6;
 67	unsigned		valid:1;
 68	unsigned		on_partial_list:1;
 69
 70	u8			dev;
 71	u8			gen;
 72	u32			sectors_free;
 73	u64			bucket;
 74	struct ec_stripe_new	*ec;
 75};
 76
 77#define OPEN_BUCKET_LIST_MAX	15
 78
 79struct open_buckets {
 80	open_bucket_idx_t	nr;
 81	open_bucket_idx_t	v[OPEN_BUCKET_LIST_MAX];
 82};
 83
 84struct dev_stripe_state {
 85	u64			next_alloc[BCH_SB_MEMBERS_MAX];
 86};
 87
 88#define WRITE_POINT_STATES()		\
 89	x(stopped)			\
 90	x(waiting_io)			\
 91	x(waiting_work)			\
 92	x(running)
 93
 94enum write_point_state {
 95#define x(n)	WRITE_POINT_##n,
 96	WRITE_POINT_STATES()
 97#undef x
 98	WRITE_POINT_STATE_NR
 99};
100
101struct write_point {
102	struct {
103		struct hlist_node	node;
104		struct mutex		lock;
105		u64			last_used;
106		unsigned long		write_point;
107		enum bch_data_type	data_type;
108
109		/* calculated based on how many pointers we're actually going to use: */
110		unsigned		sectors_free;
111
112		struct open_buckets	ptrs;
113		struct dev_stripe_state	stripe;
114
115		u64			sectors_allocated;
116	} __aligned(SMP_CACHE_BYTES);
117
118	struct {
119		struct work_struct	index_update_work;
120
121		struct list_head	writes;
122		spinlock_t		writes_lock;
123
124		enum write_point_state	state;
125		u64			last_state_change;
126		u64			time[WRITE_POINT_STATE_NR];
127	} __aligned(SMP_CACHE_BYTES);
128};
129
130struct write_point_specifier {
131	unsigned long		v;
132};
133
134#endif /* _BCACHEFS_ALLOC_TYPES_H */