mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-03 05:18:29 +03:00
format_text: Adjust metadata alignment calculation.
Use new ALIGN_ABSOLUTE macro when calculating the start location of new metadata and adjust the end of buffer detection so that there is no longer an imposed gap between old and new metadata.
This commit is contained in:
parent
053d35de47
commit
b76c6951aa
@ -1,5 +1,6 @@
|
|||||||
Version 2.02.177 -
|
Version 2.02.177 -
|
||||||
====================================
|
====================================
|
||||||
|
Refactor and adjust text format metadata alignment calculation.
|
||||||
Fix python3 path in lvmdbusd to use value detected by configure.
|
Fix python3 path in lvmdbusd to use value detected by configure.
|
||||||
Reduce checks for active LVs in vgchange before background polling.
|
Reduce checks for active LVs in vgchange before background polling.
|
||||||
Ensure _node_send_message always uses clean status of thin pool.
|
Ensure _node_send_message always uses clean status of thin pool.
|
||||||
|
@ -487,12 +487,11 @@ static uint64_t _next_rlocn_offset(struct raw_locn *rlocn, struct mda_header *md
|
|||||||
/* FIXME Assume only one VG per mdah for now */
|
/* FIXME Assume only one VG per mdah for now */
|
||||||
return alignment;
|
return alignment;
|
||||||
|
|
||||||
/* Calculate new start position within buffer rounded up to absolute alignment */
|
/* Calculate new start position relative to start of buffer rounded up to absolute alignment */
|
||||||
new_start_offset = rlocn->offset + rlocn->size +
|
new_start_offset = ALIGN_ABSOLUTE(rlocn->offset + rlocn->size, mdac_area_start, alignment);
|
||||||
(alignment - (mdac_area_start + rlocn->offset + rlocn->size) % alignment);
|
|
||||||
|
|
||||||
/* If new location is beyond the end of the buffer, wrap around back to start of circular buffer */
|
/* If new location is beyond the end of the buffer, wrap around back to start of circular buffer */
|
||||||
if (new_start_offset > mdah->size - MDA_HEADER_SIZE)
|
if (new_start_offset >= mdah->size)
|
||||||
new_start_offset -= (mdah->size - MDA_HEADER_SIZE);
|
new_start_offset -= (mdah->size - MDA_HEADER_SIZE);
|
||||||
|
|
||||||
return new_start_offset;
|
return new_start_offset;
|
||||||
@ -816,10 +815,9 @@ static int _vg_commit_raw_rlocn(struct format_instance *fid,
|
|||||||
rlocn->offset = mdac->rlocn.offset;
|
rlocn->offset = mdac->rlocn.offset;
|
||||||
rlocn->size = mdac->rlocn.size;
|
rlocn->size = mdac->rlocn.size;
|
||||||
rlocn->checksum = mdac->rlocn.checksum;
|
rlocn->checksum = mdac->rlocn.checksum;
|
||||||
log_debug_metadata("%sCommitting %s %smetadata (%u) to %s header at "
|
log_debug_metadata("%sCommitting %s %smetadata (%u) to %s header at " FMTu64 " (offset " FMTu64 ", size " FMTu64 ")",
|
||||||
FMTu64, precommit ? "Pre-" : "", vg->name,
|
precommit ? "Pre-" : "", vg->name, mda_is_ignored(mda) ? "(ignored) " : "", vg->seqno,
|
||||||
mda_is_ignored(mda) ? "(ignored) " : "", vg->seqno,
|
dev_name(mdac->area.dev), mdac->area.start, mdac->rlocn.offset, mdac->rlocn.size);
|
||||||
dev_name(mdac->area.dev), mdac->area.start);
|
|
||||||
} else
|
} else
|
||||||
log_debug_metadata("Wiping pre-committed %s %smetadata from %s "
|
log_debug_metadata("Wiping pre-committed %s %smetadata from %s "
|
||||||
"header at " FMTu64, vg->name,
|
"header at " FMTu64, vg->name,
|
||||||
@ -1282,13 +1280,13 @@ int vgname_from_mda(const struct format_type *fmt,
|
|||||||
if (!validate_name(vgsummary->vgname))
|
if (!validate_name(vgsummary->vgname))
|
||||||
return_0;
|
return_0;
|
||||||
|
|
||||||
log_debug_metadata("%s: %s metadata at " FMTu64 " size " FMTu64
|
log_debug_metadata("%s: %s metadata at " FMTu64 " size " FMTu64 " with wrap " FMTu32
|
||||||
" (in area at " FMTu64 " size " FMTu64
|
" (in area at " FMTu64 " size " FMTu64
|
||||||
") for %s (" FMTVGID ")",
|
") for %s (" FMTVGID ")",
|
||||||
dev_name(dev_area->dev),
|
dev_name(dev_area->dev),
|
||||||
used_cached_metadata ? "Using cached" : "Found",
|
used_cached_metadata ? "Using cached" : "Found",
|
||||||
dev_area->start + rlocn->offset,
|
dev_area->start + rlocn->offset,
|
||||||
rlocn->size, dev_area->start, dev_area->size, vgsummary->vgname,
|
rlocn->size, wrap, dev_area->start, dev_area->size, vgsummary->vgname,
|
||||||
(char *)&vgsummary->vgid);
|
(char *)&vgsummary->vgid);
|
||||||
|
|
||||||
if (mda_free_sectors) {
|
if (mda_free_sectors) {
|
||||||
|
Loading…
Reference in New Issue
Block a user