Previously, only split rbios allocated in io_read.c would be removed
from the async obj list.

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

diff --git a/fs/bcachefs/io_read.c b/fs/bcachefs/io_read.c
index cd184b219a65..e0874ad9a6cf 100644
--- a/fs/bcachefs/io_read.c
+++ b/fs/bcachefs/io_read.c
@@ -166,6 +166,7 @@ static noinline void promote_free(struct bch_read_bio *rbio)
        BUG_ON(ret);
 
        async_object_list_del(c, promote, op->list_idx);
+       async_object_list_del(c, rbio, rbio->list_idx);
 
        bch2_data_update_exit(&op->write);
 
@@ -456,6 +457,10 @@ static void bch2_rbio_done(struct bch_read_bio *rbio)
        if (rbio->start_time)
                bch2_time_stats_update(&rbio->c->times[BCH_TIME_data_read],
                                       rbio->start_time);
+#ifdef CONFIG_BCACHEFS_ASYNC_OBJECT_LISTS
+       if (rbio->list_idx)
+               async_object_list_del(rbio->c, rbio, rbio->list_idx);
+#endif
        bio_endio(&rbio->bio);
 }
 
-- 
2.50.0


Reply via email to