mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-02 01:18:26 +03:00
integrity: display total mismatches at raid LV level
Each integrity image in a raid LV reports its own number of integrity mismatches, e.g. lvs -o integritymismatches vg/lv_rimage_0 lvs -o integritymismatches vg/lv_rimage_1 In addition to this, allow the total number of integrity mismatches from all images to be displayed for the raid LV. lvs -o integritymismatches vg/lv shows the number of mismatches from both lv_rimage_0 and lv_rimage_1.
This commit is contained in:
parent
2317ba3934
commit
5fef89361d
@ -895,12 +895,52 @@ int lv_get_raid_integrity_settings(struct logical_volume *lv, struct integrity_s
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int lv_raid_integrity_total_mismatches(struct cmd_context *cmd,
|
||||||
|
const struct logical_volume *lv,
|
||||||
|
uint64_t *mismatches)
|
||||||
|
{
|
||||||
|
struct logical_volume *lv_image;
|
||||||
|
struct lv_segment *seg, *seg_image;
|
||||||
|
uint32_t s;
|
||||||
|
uint64_t mismatches_image;
|
||||||
|
uint64_t total = 0;
|
||||||
|
int errors = 0;
|
||||||
|
|
||||||
|
if (!lv_is_raid(lv))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
seg = first_seg(lv);
|
||||||
|
|
||||||
|
for (s = 0; s < seg->area_count; s++) {
|
||||||
|
lv_image = seg_lv(seg, s);
|
||||||
|
seg_image = first_seg(lv_image);
|
||||||
|
|
||||||
|
if (!seg_is_integrity(seg_image))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
mismatches_image = 0;
|
||||||
|
|
||||||
|
if (!lv_integrity_mismatches(cmd, lv_image, &mismatches_image))
|
||||||
|
errors++;
|
||||||
|
|
||||||
|
total += mismatches_image;
|
||||||
|
}
|
||||||
|
*mismatches = total;
|
||||||
|
|
||||||
|
if (errors)
|
||||||
|
return 0;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
int lv_integrity_mismatches(struct cmd_context *cmd,
|
int lv_integrity_mismatches(struct cmd_context *cmd,
|
||||||
const struct logical_volume *lv,
|
const struct logical_volume *lv,
|
||||||
uint64_t *mismatches)
|
uint64_t *mismatches)
|
||||||
{
|
{
|
||||||
struct lv_with_info_and_seg_status status;
|
struct lv_with_info_and_seg_status status;
|
||||||
|
|
||||||
|
if (lv_is_raid(lv) && lv_raid_has_integrity((struct logical_volume *)lv))
|
||||||
|
return lv_raid_integrity_total_mismatches(cmd, lv, mismatches);
|
||||||
|
|
||||||
if (!lv_is_integrity(lv))
|
if (!lv_is_integrity(lv))
|
||||||
return_0;
|
return_0;
|
||||||
|
|
||||||
|
@ -1433,5 +1433,6 @@ int lv_extend_integrity_in_raid(struct logical_volume *lv, struct dm_list *pvh);
|
|||||||
int lv_get_raid_integrity_settings(struct logical_volume *lv, struct integrity_settings **isettings);
|
int lv_get_raid_integrity_settings(struct logical_volume *lv, struct integrity_settings **isettings);
|
||||||
int integrity_mode_set(const char *mode, struct integrity_settings *settings);
|
int integrity_mode_set(const char *mode, struct integrity_settings *settings);
|
||||||
int lv_integrity_mismatches(struct cmd_context *cmd, const struct logical_volume *lv, uint64_t *mismatches);
|
int lv_integrity_mismatches(struct cmd_context *cmd, const struct logical_volume *lv, uint64_t *mismatches);
|
||||||
|
int lv_raid_integrity_total_mismatches(struct cmd_context *cmd, const struct logical_volume *lv, uint64_t *mismatches);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -3338,6 +3338,10 @@ static int _integritymismatches_disp(struct dm_report *rh __attribute__((unused)
|
|||||||
if (lv_is_integrity(lv) && lv_integrity_mismatches(lv->vg->cmd, lv, &mismatches))
|
if (lv_is_integrity(lv) && lv_integrity_mismatches(lv->vg->cmd, lv, &mismatches))
|
||||||
return dm_report_field_uint64(rh, field, &mismatches);
|
return dm_report_field_uint64(rh, field, &mismatches);
|
||||||
|
|
||||||
|
if (lv_is_raid(lv) && lv_raid_has_integrity(lv) &&
|
||||||
|
lv_raid_integrity_total_mismatches(lv->vg->cmd, lv, &mismatches))
|
||||||
|
return dm_report_field_uint64(rh, field, &mismatches);
|
||||||
|
|
||||||
return _field_set_value(field, "", &GET_TYPE_RESERVED_VALUE(num_undef_64));
|
return _field_set_value(field, "", &GET_TYPE_RESERVED_VALUE(num_undef_64));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user