+/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _BCACHEFS_ALLOC_TYPES_H
#define _BCACHEFS_ALLOC_TYPES_H
#include <linux/spinlock.h>
#include "clock_types.h"
+#include "fifo.h"
-/*
- * There's two of these clocks, one for reads and one for writes:
- *
- * All fields protected by bucket_lock
- */
-struct prio_clock {
+struct ec_bucket_buf;
+
+/* There's two of these clocks, one for reads and one for writes: */
+struct bucket_clock {
/*
* "now" in (read/write) IO time - incremented whenever we do X amount
* of reads or writes.
* consistent.
*/
u16 hand;
- u16 min_prio;
+ u16 max_last_io;
int rw;
struct io_timer rescale;
+ struct mutex lock;
};
/* There is one reserve for each type of btree, one for prios and gens
RESERVE_NR = 3,
};
-/* Enough for 16 cache devices, 2 tiers and some left over for pipelining */
-#define OPEN_BUCKETS_COUNT 256
-#define WRITE_POINT_COUNT 32
+typedef FIFO(long) alloc_fifo;
-struct open_bucket_ptr {
- struct bch_extent_ptr ptr;
- unsigned sectors_free;
-};
+#define OPEN_BUCKETS_COUNT 1024
+
+#define WRITE_POINT_HASH_NR 32
+#define WRITE_POINT_MAX 32
+
+typedef u16 open_bucket_idx_t;
struct open_bucket {
spinlock_t lock;
atomic_t pin;
- u8 freelist;
- u8 new_ob;
- u8 nr_ptrs;
+ open_bucket_idx_t freelist;
+
+ /*
+ * When an open bucket has an ec_stripe attached, this is the index of
+ * the block in the stripe this open_bucket corresponds to:
+ */
+ u8 ec_idx;
+ u8 type;
+ unsigned valid:1;
+ unsigned on_partial_list:1;
+ unsigned sectors_free;
+ struct bch_extent_ptr ptr;
+ struct ec_stripe_new *ec;
+};
+
+#define OPEN_BUCKET_LIST_MAX 15
+
+struct open_buckets {
+ open_bucket_idx_t nr;
+ open_bucket_idx_t v[OPEN_BUCKET_LIST_MAX];
+};
- struct open_bucket_ptr ptrs[BCH_REPLICAS_MAX * 2];
+struct dev_stripe_state {
+ u64 next_alloc[BCH_SB_MEMBERS_MAX];
};
struct write_point {
u64 last_used;
unsigned long write_point;
enum bch_data_type type;
+ bool is_ec;
/* calculated based on how many pointers we're actually going to use: */
unsigned sectors_free;
- struct open_bucket *ob;
- u64 next_alloc[BCH_SB_MEMBERS_MAX];
+ struct open_buckets ptrs;
+ struct dev_stripe_state stripe;
+};
+
+struct write_point_specifier {
+ unsigned long v;
};
struct alloc_heap_entry {
size_t bucket;
+ size_t nr;
unsigned long key;
};