unsigned i;
        int ret = 0;
 
-       for_each_rw_member(ca, c, i) {
+       for_each_member_device(ca, c, i) {
                bch2_dev_alloc_write(c, ca, flags);
                if (ret) {
                        percpu_ref_put(&ca->io_ref);
 
 
        /* misc: */
        BCH_FS_FIXED_GENS,
-       BCH_FS_ALLOC_WRITTEN,
+       BCH_FS_NEED_ALLOC_WRITE,
        BCH_FS_REBUILD_REPLICAS,
        BCH_FS_HOLD_BTREE_WRITES,
 };
 
                                        ptr->gen)) {
                                g2->_mark.gen   = g->_mark.gen          = ptr->gen;
                                g2->gen_valid   = g->gen_valid          = true;
+                               set_bit(BCH_FS_NEED_ALLOC_WRITE, &c->flags);
                        }
 
                        if (mustfix_fsck_err_on(gen_cmp(ptr->gen, g->mark.gen) > 0, c,
                                g2->_mark.dirty_sectors         = 0;
                                g2->_mark.cached_sectors        = 0;
                                set_bit(BCH_FS_FIXED_GENS, &c->flags);
+                               set_bit(BCH_FS_NEED_ALLOC_WRITE, &c->flags);
                        }
                }
        }
                        fsck_err(c, _msg ": got %llu, should be %llu"   \
                                , ##__VA_ARGS__, dst->_f, src->_f);     \
                dst->_f = src->_f;                                      \
-               ret = 1;                                                \
+               set_bit(BCH_FS_NEED_ALLOC_WRITE, &c->flags);            \
        }
 #define copy_stripe_field(_f, _msg, ...)                               \
        if (dst->_f != src->_f) {                                       \
                                dst->_f, src->_f);                      \
                dst->_f = src->_f;                                      \
                dst->dirty = true;                                      \
-               ret = 1;                                                \
+               set_bit(BCH_FS_NEED_ALLOC_WRITE, &c->flags);            \
        }
 #define copy_bucket_field(_f)                                          \
        if (dst->b[b].mark._f != src->b[b].mark._f) {                   \
                                bch2_data_types[dst->b[b].mark.data_type],\
                                dst->b[b].mark._f, src->b[b].mark._f);  \
                dst->b[b]._mark._f = src->b[b].mark._f;                 \
-               ret = 1;                                                \
+               set_bit(BCH_FS_NEED_ALLOC_WRITE, &c->flags);            \
        }
 #define copy_dev_field(_f, _msg, ...)                                  \
        copy_field(_f, "dev %u has wrong " _msg, i, ##__VA_ARGS__)
 
        struct bch_sb_field_clean *clean = NULL;
        struct jset *last_journal_entry = NULL;
        u64 blacklist_seq, journal_seq;
-       bool write_sb = false, need_write_alloc = false;
+       bool write_sb = false;
        int ret;
 
        if (c->sb.clean)
                bch_info(c, "starting metadata mark and sweep");
                err = "error in mark and sweep";
                ret = bch2_gc(c, &c->journal_keys, true, true);
-               if (ret < 0)
-                       goto err;
                if (ret)
-                       need_write_alloc = true;
+                       goto err;
                bch_verbose(c, "mark and sweep done");
        }
 
                bch_info(c, "starting mark and sweep");
                err = "error in mark and sweep";
                ret = bch2_gc(c, &c->journal_keys, true, false);
-               if (ret < 0)
-                       goto err;
                if (ret)
-                       need_write_alloc = true;
+                       goto err;
                bch_verbose(c, "mark and sweep done");
        }
 
                goto err;
        bch_verbose(c, "journal replay done");
 
-       if (need_write_alloc && !c->opts.nochanges) {
+       if (test_bit(BCH_FS_NEED_ALLOC_WRITE, &c->flags) &&
+           !c->opts.nochanges) {
                /*
                 * note that even when filesystem was clean there might be work
                 * to do here, if we ran gc (because of fsck) which recalculated
                        goto err;
                }
                bch_verbose(c, "alloc write done");
-
-               set_bit(BCH_FS_ALLOC_WRITTEN, &c->flags);
        }
 
        if (!c->sb.clean) {