|
@@ -1440,17 +1440,19 @@ static int nilfs_segctor_collect(struct nilfs_sc_info *sci,
|
|
|
|
|
|
nilfs_clear_logs(&sci->sc_segbufs);
|
|
nilfs_clear_logs(&sci->sc_segbufs);
|
|
|
|
|
|
- err = nilfs_segctor_extend_segments(sci, nilfs, nadd);
|
|
|
|
- if (unlikely(err))
|
|
|
|
- return err;
|
|
|
|
-
|
|
|
|
if (sci->sc_stage.flags & NILFS_CF_SUFREED) {
|
|
if (sci->sc_stage.flags & NILFS_CF_SUFREED) {
|
|
err = nilfs_sufile_cancel_freev(nilfs->ns_sufile,
|
|
err = nilfs_sufile_cancel_freev(nilfs->ns_sufile,
|
|
sci->sc_freesegs,
|
|
sci->sc_freesegs,
|
|
sci->sc_nfreesegs,
|
|
sci->sc_nfreesegs,
|
|
NULL);
|
|
NULL);
|
|
WARN_ON(err); /* do not happen */
|
|
WARN_ON(err); /* do not happen */
|
|
|
|
+ sci->sc_stage.flags &= ~NILFS_CF_SUFREED;
|
|
}
|
|
}
|
|
|
|
+
|
|
|
|
+ err = nilfs_segctor_extend_segments(sci, nilfs, nadd);
|
|
|
|
+ if (unlikely(err))
|
|
|
|
+ return err;
|
|
|
|
+
|
|
nadd = min_t(int, nadd << 1, SC_MAX_SEGDELTA);
|
|
nadd = min_t(int, nadd << 1, SC_MAX_SEGDELTA);
|
|
sci->sc_stage = prev_stage;
|
|
sci->sc_stage = prev_stage;
|
|
}
|
|
}
|