summaryrefslogtreecommitdiff
path: root/fs/bcachefs/move_types.h
diff options
context:
space:
mode:
authorKent Overstreet <kent.overstreet@linux.dev>2023-02-28 06:58:01 +0300
committerKent Overstreet <kent.overstreet@linux.dev>2023-10-23 00:09:56 +0300
commit8fcdf81418f16ef878de7a7535e90599e396fd69 (patch)
tree1bbef7695558d893d8000d486c9b8e8006f19776 /fs/bcachefs/move_types.h
parent0b943b973c67c2780cb991c3011ad3279f670fa4 (diff)
downloadlinux-8fcdf81418f16ef878de7a7535e90599e396fd69.tar.xz
bcachefs: Improved copygc pipelining
This improves copygc pipelining across multiple buckets: we now track each in flight bucket we're evacuating, with separate moving_contexts. This means that whereas previously we had to wait for outstanding moves to complete to ensure we didn't try to evacuate the same bucket twice, we can now just check buckets we want to evacuate against the pending list. This also mean we can run the verify_bucket_evacuated() check without killing pipelining - meaning it can now always be enabled, not just on debug builds. This is going to be important for the upcoming erasure coding work, where moving IOs that are being erasure coded will now skip the initial replication step; instead the IOs will wait on the stripe to complete. Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
Diffstat (limited to 'fs/bcachefs/move_types.h')
-rw-r--r--fs/bcachefs/move_types.h6
1 files changed, 6 insertions, 0 deletions
diff --git a/fs/bcachefs/move_types.h b/fs/bcachefs/move_types.h
index 9df6d18137a5..285ffdb762ac 100644
--- a/fs/bcachefs/move_types.h
+++ b/fs/bcachefs/move_types.h
@@ -16,4 +16,10 @@ struct bch_move_stats {
atomic64_t sectors_raced;
};
+struct move_bucket_in_flight {
+ struct bpos bucket;
+ u8 gen;
+ atomic_t count;
+};
+
#endif /* _BCACHEFS_MOVE_TYPES_H */