mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-11 09:18:25 +03:00
o New function 'merge_segments'
o Call said function at end of lv_extend
This commit is contained in:
parent
aedc729087
commit
3cd47b5c9b
@ -37,6 +37,7 @@ SOURCES=\
|
||||
label/label.c \
|
||||
log/log.c \
|
||||
metadata/lv_manip.c \
|
||||
metadata/merge.c \
|
||||
metadata/metadata.c \
|
||||
metadata/pv_map.c \
|
||||
mm/dbg_malloc.c \
|
||||
|
@ -9,6 +9,7 @@
|
||||
#include "log.h"
|
||||
#include "dbg_malloc.h"
|
||||
#include "lvm-string.h"
|
||||
#include "merge.h"
|
||||
|
||||
#include <assert.h>
|
||||
|
||||
@ -497,6 +498,12 @@ int lv_extend(struct logical_volume *lv,
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (!merge_segments(lv)) {
|
||||
log_err("Couldn't merge segments after extending "
|
||||
"logical volume.");
|
||||
return 0;
|
||||
}
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
55
lib/metadata/merge.c
Normal file
55
lib/metadata/merge.c
Normal file
@ -0,0 +1,55 @@
|
||||
/*
|
||||
* Copyright (C) 2001 Sistina Software
|
||||
*
|
||||
* This file is released under the LGPL.
|
||||
*/
|
||||
|
||||
#include "log.h"
|
||||
#include "merge.h"
|
||||
|
||||
/*
|
||||
* Returns success if the segments were
|
||||
* successfully merged. If the do merge, 'first'
|
||||
* will be adjusted to contain both areas.
|
||||
*/
|
||||
static int _merge(struct stripe_segment *first, struct stripe_segment *second)
|
||||
{
|
||||
int s;
|
||||
uint32_t width;
|
||||
|
||||
if (!first ||
|
||||
(first->stripes != second->stripes) ||
|
||||
(first->stripe_size != second->stripe_size))
|
||||
return 0;
|
||||
|
||||
for (s = 0; s < first->stripes; s++) {
|
||||
width = first->len / first->stripes;
|
||||
|
||||
if ((first->area[s].pv != second->area[s].pv) ||
|
||||
(first->area[s].pe + width != second->area[s].pe))
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* we should merge */
|
||||
first->len += second->len;
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
int merge_segments(struct logical_volume *lv)
|
||||
{
|
||||
struct list *segh;
|
||||
struct stripe_segment *current, *prev = NULL;
|
||||
|
||||
list_iterate (segh, &lv->segments) {
|
||||
current = list_item(segh, struct stripe_segment);
|
||||
|
||||
if (_merge(prev, current))
|
||||
list_del(¤t->list);
|
||||
else
|
||||
prev = current;
|
||||
}
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
20
lib/metadata/merge.h
Normal file
20
lib/metadata/merge.h
Normal file
@ -0,0 +1,20 @@
|
||||
/*
|
||||
* Copyright (C) 2001 Sistina Software
|
||||
*
|
||||
* This file is released under the LGPL.
|
||||
*/
|
||||
|
||||
#ifndef _LVM_MERGE_H
|
||||
#define _LVM_MERGE_H
|
||||
|
||||
#include "metadata.h"
|
||||
|
||||
/*
|
||||
* Sometimes (eg, after an lvextend), it is
|
||||
* possible to merge two adjacent segments into a
|
||||
* single segment. This function trys to merge as
|
||||
* many segments as possible.
|
||||
*/
|
||||
int merge_segments(struct logical_volume *lv);
|
||||
|
||||
#endif /* _LVM_MERGE_H */
|
Loading…
Reference in New Issue
Block a user