Commit 5c88f403 authored by Song Liu's avatar Song Liu Committed by Shaohua Li

md/raid5-cache: fix crc in rewrite_data_only_stripes()

r5l_recovery_create_empty_meta_block() creates crc for the empty
metablock. After the metablock is updated, we need clear the
checksum before recalculate it.

Shaohua: moved checksum calculation out of
r5l_recovery_create_empty_meta_block. We should calculate it after all fields
are updated.
Signed-off-by: default avatarSong Liu <songliubraving@fb.com>
Signed-off-by: default avatarShaohua Li <shli@fb.com>
parent d30dfeb9
...@@ -1522,7 +1522,6 @@ r5l_recovery_create_empty_meta_block(struct r5l_log *log, ...@@ -1522,7 +1522,6 @@ r5l_recovery_create_empty_meta_block(struct r5l_log *log,
sector_t pos, u64 seq) sector_t pos, u64 seq)
{ {
struct r5l_meta_block *mb; struct r5l_meta_block *mb;
u32 crc;
mb = page_address(page); mb = page_address(page);
clear_page(mb); clear_page(mb);
...@@ -1531,19 +1530,21 @@ r5l_recovery_create_empty_meta_block(struct r5l_log *log, ...@@ -1531,19 +1530,21 @@ r5l_recovery_create_empty_meta_block(struct r5l_log *log,
mb->meta_size = cpu_to_le32(sizeof(struct r5l_meta_block)); mb->meta_size = cpu_to_le32(sizeof(struct r5l_meta_block));
mb->seq = cpu_to_le64(seq); mb->seq = cpu_to_le64(seq);
mb->position = cpu_to_le64(pos); mb->position = cpu_to_le64(pos);
crc = crc32c_le(log->uuid_checksum, mb, PAGE_SIZE);
mb->checksum = cpu_to_le32(crc);
} }
static int r5l_log_write_empty_meta_block(struct r5l_log *log, sector_t pos, static int r5l_log_write_empty_meta_block(struct r5l_log *log, sector_t pos,
u64 seq) u64 seq)
{ {
struct page *page; struct page *page;
struct r5l_meta_block *mb;
page = alloc_page(GFP_KERNEL); page = alloc_page(GFP_KERNEL);
if (!page) if (!page)
return -ENOMEM; return -ENOMEM;
r5l_recovery_create_empty_meta_block(log, page, pos, seq); r5l_recovery_create_empty_meta_block(log, page, pos, seq);
mb = page_address(page);
mb->checksum = cpu_to_le32(crc32c_le(log->uuid_checksum,
mb, PAGE_SIZE));
if (!sync_page_io(log->rdev, pos, PAGE_SIZE, page, REQ_OP_WRITE, if (!sync_page_io(log->rdev, pos, PAGE_SIZE, page, REQ_OP_WRITE,
WRITE_FUA, false)) { WRITE_FUA, false)) {
__free_page(page); __free_page(page);
...@@ -2117,7 +2118,8 @@ r5c_recovery_rewrite_data_only_stripes(struct r5l_log *log, ...@@ -2117,7 +2118,8 @@ r5c_recovery_rewrite_data_only_stripes(struct r5l_log *log,
} }
} }
mb->meta_size = cpu_to_le32(offset); mb->meta_size = cpu_to_le32(offset);
mb->checksum = crc32c_le(log->uuid_checksum, mb, PAGE_SIZE); mb->checksum = cpu_to_le32(crc32c_le(log->uuid_checksum,
mb, PAGE_SIZE));
sync_page_io(log->rdev, ctx->pos, PAGE_SIZE, page, sync_page_io(log->rdev, ctx->pos, PAGE_SIZE, page,
REQ_OP_WRITE, WRITE_FUA, false); REQ_OP_WRITE, WRITE_FUA, false);
sh->log_start = ctx->pos; sh->log_start = ctx->pos;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment