1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-04 09:18:36 +03:00

metadata: remember crc32 when writing vg metadata

Preserve computed crc32 check from first written PV, just like we
preserve generated metadata.

Also there is no need to call crc32 twice on wrapping buffer with 2 calcs,
result must be always the same as with single crc32 checking.
This commit is contained in:
Zdenek Kabelac 2021-09-27 11:41:03 +02:00
parent a3352f08f6
commit a42ea349f6
2 changed files with 7 additions and 7 deletions

View File

@ -1,5 +1,6 @@
Version 2.03.14 - Version 2.03.14 -
================================== ==================================
Optimize computation of crc32 check sum with multiple PVs.
Enhance recover path on cache creation failure. Enhance recover path on cache creation failure.
Filter out unsupported MQ/SMQ cache policy setting. Filter out unsupported MQ/SMQ cache policy setting.
Fix memleak in mpath filter. Fix memleak in mpath filter.

View File

@ -42,6 +42,7 @@ struct text_fid_context {
char *write_buf; /* buffer containing metadata text to write to disk */ char *write_buf; /* buffer containing metadata text to write to disk */
uint32_t write_buf_size; /* mem size of write_buf, increases in 64K multiples */ uint32_t write_buf_size; /* mem size of write_buf, increases in 64K multiples */
uint32_t new_metadata_size; /* size of text metadata in buf */ uint32_t new_metadata_size; /* size of text metadata in buf */
uint32_t checksum; /* crc32 checksum for new metadata */
unsigned preserve:1; unsigned preserve:1;
}; };
@ -542,6 +543,7 @@ static int _vg_write_raw(struct format_instance *fid, struct volume_group *vg,
uint64_t write2_start = 0, write2_last = 0, write2_size = 0; uint64_t write2_start = 0, write2_last = 0, write2_size = 0;
uint32_t write1_over = 0, write2_over = 0; uint32_t write1_over = 0, write2_over = 0;
uint32_t write_buf_size; uint32_t write_buf_size;
uint32_t checksum;
uint32_t extra_size; uint32_t extra_size;
uint32_t bad_fields = 0; uint32_t bad_fields = 0;
char *write_buf = NULL; char *write_buf = NULL;
@ -601,6 +603,7 @@ static int _vg_write_raw(struct format_instance *fid, struct volume_group *vg,
write_buf = fidtc->write_buf; write_buf = fidtc->write_buf;
write_buf_size = fidtc->write_buf_size; write_buf_size = fidtc->write_buf_size;
new_size = fidtc->new_metadata_size; new_size = fidtc->new_metadata_size;
checksum = fidtc->checksum;
} else { } else {
if (!vg->write_count++) if (!vg->write_count++)
(void) dm_snprintf(desc, sizeof(desc), "Write from %s.", vg->cmd->cmd_line); (void) dm_snprintf(desc, sizeof(desc), "Write from %s.", vg->cmd->cmd_line);
@ -631,6 +634,8 @@ static int _vg_write_raw(struct format_instance *fid, struct volume_group *vg,
dm_config_destroy(cft); dm_config_destroy(cft);
if (!vg->vg_precommitted) if (!vg->vg_precommitted)
goto_out; goto_out;
fidtc->checksum = checksum = calc_crc(INITIAL_CRC, (uint8_t *)write_buf, new_size);
} }
log_debug_metadata("VG %s seqno %u metadata write to %s mda_start %llu mda_size %llu mda_last %llu", log_debug_metadata("VG %s seqno %u metadata write to %s mda_start %llu mda_size %llu mda_last %llu",
@ -954,13 +959,7 @@ static int _vg_write_raw(struct format_instance *fid, struct volume_group *vg,
dev_unset_last_byte(mdac->area.dev); dev_unset_last_byte(mdac->area.dev);
rlocn_new->checksum = calc_crc(INITIAL_CRC, rlocn_new->checksum = checksum;
(uint8_t *)write_buf,
(uint32_t)(new_size - new_wrap));
if (new_wrap)
rlocn_new->checksum = calc_crc(rlocn_new->checksum,
(uint8_t *)write_buf + new_size - new_wrap,
(uint32_t)new_wrap);
r = 1; r = 1;