diff options
Diffstat (limited to 'fs/nilfs2/super.c')
-rw-r--r-- | fs/nilfs2/super.c | 30 |
1 files changed, 17 insertions, 13 deletions
diff --git a/fs/nilfs2/super.c b/fs/nilfs2/super.c index 4a85dfb70b8e..c5328c8ba1d2 100644 --- a/fs/nilfs2/super.c +++ b/fs/nilfs2/super.c | |||
@@ -237,13 +237,27 @@ static int nilfs_sync_super(struct nilfs_sb_info *sbi, int dupsb) | |||
237 | return err; | 237 | return err; |
238 | } | 238 | } |
239 | 239 | ||
240 | void nilfs_set_log_cursor(struct nilfs_super_block *sbp, | ||
241 | struct the_nilfs *nilfs) | ||
242 | { | ||
243 | sector_t nfreeblocks; | ||
244 | |||
245 | /* nilfs->ns_sem must be locked by the caller. */ | ||
246 | nilfs_count_free_blocks(nilfs, &nfreeblocks); | ||
247 | sbp->s_free_blocks_count = cpu_to_le64(nfreeblocks); | ||
248 | |||
249 | spin_lock(&nilfs->ns_last_segment_lock); | ||
250 | sbp->s_last_seq = cpu_to_le64(nilfs->ns_last_seq); | ||
251 | sbp->s_last_pseg = cpu_to_le64(nilfs->ns_last_pseg); | ||
252 | sbp->s_last_cno = cpu_to_le64(nilfs->ns_last_cno); | ||
253 | spin_unlock(&nilfs->ns_last_segment_lock); | ||
254 | } | ||
255 | |||
240 | int nilfs_commit_super(struct nilfs_sb_info *sbi, int dupsb) | 256 | int nilfs_commit_super(struct nilfs_sb_info *sbi, int dupsb) |
241 | { | 257 | { |
242 | struct the_nilfs *nilfs = sbi->s_nilfs; | 258 | struct the_nilfs *nilfs = sbi->s_nilfs; |
243 | struct nilfs_super_block **sbp = nilfs->ns_sbp; | 259 | struct nilfs_super_block **sbp = nilfs->ns_sbp; |
244 | sector_t nfreeblocks; | ||
245 | time_t t; | 260 | time_t t; |
246 | int err; | ||
247 | 261 | ||
248 | /* nilfs->sem must be locked by the caller. */ | 262 | /* nilfs->sem must be locked by the caller. */ |
249 | if (sbp[0]->s_magic != cpu_to_le16(NILFS_SUPER_MAGIC)) { | 263 | if (sbp[0]->s_magic != cpu_to_le16(NILFS_SUPER_MAGIC)) { |
@@ -255,20 +269,10 @@ int nilfs_commit_super(struct nilfs_sb_info *sbi, int dupsb) | |||
255 | return -EIO; | 269 | return -EIO; |
256 | } | 270 | } |
257 | } | 271 | } |
258 | err = nilfs_count_free_blocks(nilfs, &nfreeblocks); | 272 | nilfs_set_log_cursor(sbp[0], nilfs); |
259 | if (unlikely(err)) { | ||
260 | printk(KERN_ERR "NILFS: failed to count free blocks\n"); | ||
261 | return err; | ||
262 | } | ||
263 | spin_lock(&nilfs->ns_last_segment_lock); | ||
264 | sbp[0]->s_last_seq = cpu_to_le64(nilfs->ns_last_seq); | ||
265 | sbp[0]->s_last_pseg = cpu_to_le64(nilfs->ns_last_pseg); | ||
266 | sbp[0]->s_last_cno = cpu_to_le64(nilfs->ns_last_cno); | ||
267 | spin_unlock(&nilfs->ns_last_segment_lock); | ||
268 | 273 | ||
269 | t = get_seconds(); | 274 | t = get_seconds(); |
270 | nilfs->ns_sbwtime[0] = t; | 275 | nilfs->ns_sbwtime[0] = t; |
271 | sbp[0]->s_free_blocks_count = cpu_to_le64(nfreeblocks); | ||
272 | sbp[0]->s_wtime = cpu_to_le64(t); | 276 | sbp[0]->s_wtime = cpu_to_le64(t); |
273 | sbp[0]->s_sum = 0; | 277 | sbp[0]->s_sum = 0; |
274 | sbp[0]->s_sum = cpu_to_le32(crc32_le(nilfs->ns_crc_seed, | 278 | sbp[0]->s_sum = cpu_to_le32(crc32_le(nilfs->ns_crc_seed, |