diff options
author | Joel Becker <joel.becker@oracle.com> | 2010-03-31 21:25:44 -0400 |
---|---|---|
committer | Joel Becker <joel.becker@oracle.com> | 2010-03-31 21:39:08 -0400 |
commit | a42ab8e1a37257da37e0f018e707bf365ac24531 (patch) | |
tree | 4d85320533c3475560a36f8735fb4874680c8d12 /fs/ocfs2/buffer_head_io.c | |
parent | 428257f8870f0e72e85ce782d091fa1f366de7df (diff) |
ocfs2: Compute metaecc for superblocks during online resize.
Online resize writes out the new superblock and its backups directly.
The metaecc data wasn't being recomputed. Let's do that directly.
Signed-off-by: Joel Becker <joel.becker@oracle.com>
Acked-by: Mark Fasheh <mfasheh@suse.com>[
Cc: stable@kernel.org
Diffstat (limited to 'fs/ocfs2/buffer_head_io.c')
-rw-r--r-- | fs/ocfs2/buffer_head_io.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/fs/ocfs2/buffer_head_io.c b/fs/ocfs2/buffer_head_io.c index 21c808f752d8..b18c6d677f9d 100644 --- a/fs/ocfs2/buffer_head_io.c +++ b/fs/ocfs2/buffer_head_io.c | |||
@@ -407,6 +407,7 @@ int ocfs2_write_super_or_backup(struct ocfs2_super *osb, | |||
407 | struct buffer_head *bh) | 407 | struct buffer_head *bh) |
408 | { | 408 | { |
409 | int ret = 0; | 409 | int ret = 0; |
410 | struct ocfs2_dinode *di = (struct ocfs2_dinode *)bh->b_data; | ||
410 | 411 | ||
411 | mlog_entry_void(); | 412 | mlog_entry_void(); |
412 | 413 | ||
@@ -426,6 +427,7 @@ int ocfs2_write_super_or_backup(struct ocfs2_super *osb, | |||
426 | 427 | ||
427 | get_bh(bh); /* for end_buffer_write_sync() */ | 428 | get_bh(bh); /* for end_buffer_write_sync() */ |
428 | bh->b_end_io = end_buffer_write_sync; | 429 | bh->b_end_io = end_buffer_write_sync; |
430 | ocfs2_compute_meta_ecc(osb->sb, bh->b_data, &di->i_check); | ||
429 | submit_bh(WRITE, bh); | 431 | submit_bh(WRITE, bh); |
430 | 432 | ||
431 | wait_on_buffer(bh); | 433 | wait_on_buffer(bh); |