This fixes a kasan splat in the ec device removal tests.

Signed-off-by: Kent Overstreet <[email protected]>
---
 fs/bcachefs/replicas.c | 5 +++++
 1 file changed, 5 insertions(+)

diff --git a/fs/bcachefs/replicas.c b/fs/bcachefs/replicas.c
index 797da1032318..477ef0997949 100644
--- a/fs/bcachefs/replicas.c
+++ b/fs/bcachefs/replicas.c
@@ -821,6 +821,11 @@ bool bch2_have_enough_devs(struct bch_fs *c, struct 
bch_devs_mask devs,
 
                rcu_read_lock();
                for (unsigned i = 0; i < e->nr_devs; i++) {
+                       if (e->devs[i] == BCH_SB_MEMBER_INVALID) {
+                               nr_failed++;
+                               continue;
+                       }
+
                        nr_online += test_bit(e->devs[i], devs.d);
 
                        struct bch_dev *ca = bch2_dev_rcu_noerror(c, 
e->devs[i]);
-- 
2.45.2


Reply via email to