mirror of
git://sourceware.org/git/lvm2.git
synced 2024-12-21 13:34:40 +03:00
cachevol: generate a unique name when creating
When a cachevol is automatically created, if the default name conflicts with an existing name, generate a new unique name.
This commit is contained in:
parent
3c9177fdc0
commit
085760992d
@ -208,5 +208,15 @@ lvchange -ay $vg/$lv1
|
||||
lvchange -an $vg/$lv1
|
||||
lvremove $vg/$lv1
|
||||
|
||||
# if the cache name is used generate a new name
|
||||
lvcreate -n $lv1 -l8 -an $vg @slow
|
||||
lvcreate -n ${lv1}_cache -l1 -an $vg @slow
|
||||
lvconvert -y --type writecache --cachedevice @fast --cachesize 8M $vg/$lv1
|
||||
check lv_field $vg/$lv1 segtype writecache
|
||||
check lv_field $vg/${lv1}_cache0_cvol lv_size "8.00m"
|
||||
lvchange -ay $vg/$lv1
|
||||
lvchange -an $vg/$lv1
|
||||
lvremove $vg/$lv1
|
||||
|
||||
vgremove -ff $vg
|
||||
|
||||
|
@ -4267,6 +4267,7 @@ static int _lv_create_cachevol(struct cmd_context *cmd,
|
||||
struct logical_volume **cachevol_lv)
|
||||
{
|
||||
char cvname[NAME_LEN];
|
||||
char format[NAME_LEN];
|
||||
struct dm_list *use_pvh;
|
||||
struct pv_list *pvl;
|
||||
char *dev_name;
|
||||
@ -4373,6 +4374,19 @@ static int _lv_create_cachevol(struct cmd_context *cmd,
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (find_lv(vg, cvname)) {
|
||||
memset(format, 0, sizeof(cvname));
|
||||
memset(cvname, 0, sizeof(cvname));
|
||||
if (dm_snprintf(format, sizeof(format), "%s_cache%%d", lv->name) < 0) {
|
||||
log_error("Failed to generate cachevol LV format.");
|
||||
return 0;
|
||||
}
|
||||
if (!generate_lv_name(vg, format, cvname, sizeof(cvname))) {
|
||||
log_error("Failed to generate cachevol LV name.");
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
lp.lv_name = cvname;
|
||||
lp.pvh = use_pvh;
|
||||
lp.extents = cache_size_sectors / vg->extent_size;
|
||||
|
Loading…
Reference in New Issue
Block a user