mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-04 09:18:36 +03:00
Merge branch 'master' of git+ssh://sourceware.org/git/lvm2
This commit is contained in:
commit
db0560c1b0
2
lib/cache/lvmcache.c
vendored
2
lib/cache/lvmcache.c
vendored
@ -359,7 +359,7 @@ struct volume_group *lvmcache_get_saved_vg(const char *vgid, int precommitted)
|
|||||||
* By just dropping old, we force a subsequent request for old to
|
* By just dropping old, we force a subsequent request for old to
|
||||||
* reread it rather than just using new. */
|
* reread it rather than just using new. */
|
||||||
|
|
||||||
if (vginfo->saved_vg_old && (vginfo->saved_vg_old < vg->seqno)) {
|
if (vginfo->saved_vg_old && (vginfo->saved_vg_old->seqno < vg->seqno)) {
|
||||||
log_debug_cache("lvmcache: drop saved_vg_old because new invalidates");
|
log_debug_cache("lvmcache: drop saved_vg_old because new invalidates");
|
||||||
_saved_vg_free(vginfo, 1, 0);
|
_saved_vg_free(vginfo, 1, 0);
|
||||||
}
|
}
|
||||||
|
@ -946,7 +946,14 @@ bool dev_write_bytes(struct device *dev, off_t start, size_t len, void *data)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!bcache_write_bytes(scan_bcache, dev->bcache_fd, start, len, data)) {
|
if (!bcache_write_bytes(scan_bcache, dev->bcache_fd, start, len, data)) {
|
||||||
log_error("dev_write_bytes %s at %u failed invalidate fd %d",
|
log_error("dev_write_bytes %s at %u bcache write failed invalidate fd %d",
|
||||||
|
dev_name(dev), (uint32_t)start, dev->bcache_fd);
|
||||||
|
label_scan_invalidate(dev);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!bcache_flush(scan_bcache)) {
|
||||||
|
log_error("dev_write_bytes %s at %u bcache flush failed invalidate fd %d",
|
||||||
dev_name(dev), (uint32_t)start, dev->bcache_fd);
|
dev_name(dev), (uint32_t)start, dev->bcache_fd);
|
||||||
label_scan_invalidate(dev);
|
label_scan_invalidate(dev);
|
||||||
return false;
|
return false;
|
||||||
@ -982,7 +989,14 @@ bool dev_write_zeros(struct device *dev, off_t start, size_t len)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!bcache_write_zeros(scan_bcache, dev->bcache_fd, start, len)) {
|
if (!bcache_write_zeros(scan_bcache, dev->bcache_fd, start, len)) {
|
||||||
log_error("dev_write_zeros %s at %u failed invalidate fd %d",
|
log_error("dev_write_zeros %s at %u bcache write failed invalidate fd %d",
|
||||||
|
dev_name(dev), (uint32_t)start, dev->bcache_fd);
|
||||||
|
label_scan_invalidate(dev);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!bcache_flush(scan_bcache)) {
|
||||||
|
log_error("dev_write_zeros %s at %u bcache flush failed invalidate fd %d",
|
||||||
dev_name(dev), (uint32_t)start, dev->bcache_fd);
|
dev_name(dev), (uint32_t)start, dev->bcache_fd);
|
||||||
label_scan_invalidate(dev);
|
label_scan_invalidate(dev);
|
||||||
return false;
|
return false;
|
||||||
|
@ -24,11 +24,13 @@ test ! -e "$LVM_LVMETAD_PIDFILE"
|
|||||||
|
|
||||||
aux lvmconf "global/use_lvmetad = 0"
|
aux lvmconf "global/use_lvmetad = 0"
|
||||||
|
|
||||||
pvcreate --metadatatype 1 "$dev1"
|
pvcreate "$dev1"
|
||||||
pvcreate "$dev2"
|
pvcreate "$dev2"
|
||||||
vgcreate -M1 $vg1 "$dev1"
|
vgcreate $vg1 "$dev1"
|
||||||
vgcreate $vg2 "$dev2"
|
vgcreate $vg2 "$dev2"
|
||||||
|
|
||||||
|
lvcreate -n $lv1 -l1 $vg1
|
||||||
|
|
||||||
pvs 2>&1 | tee out
|
pvs 2>&1 | tee out
|
||||||
grep "$dev1" out
|
grep "$dev1" out
|
||||||
grep "$dev2" out
|
grep "$dev2" out
|
||||||
@ -43,10 +45,21 @@ while ! test -e "$TESTDIR/lvmetad.socket"; do echo -n .; sleep .1; done # wait f
|
|||||||
test -e "$LVM_LVMETAD_PIDFILE"
|
test -e "$LVM_LVMETAD_PIDFILE"
|
||||||
cp "$LVM_LVMETAD_PIDFILE" LOCAL_LVMETAD
|
cp "$LVM_LVMETAD_PIDFILE" LOCAL_LVMETAD
|
||||||
|
|
||||||
pvscan --cache 2>&1 | tee out
|
pvscan --cache
|
||||||
|
pvs 2>&1 | tee out
|
||||||
|
grep "$dev1" out
|
||||||
|
grep "$dev2" out
|
||||||
|
not grep "WARNING: Not using lvmetad" out
|
||||||
|
|
||||||
|
# We don't care about the repair, and we know it's
|
||||||
|
# not valid on this lv. We are just running repair
|
||||||
|
# because we know one side effect is to disable lvmetad.
|
||||||
|
# FIXME: we should install lvmetactl so that we can
|
||||||
|
# use that to directly disable lvmetad for tests like this.
|
||||||
|
not lvconvert --repair $vg1/$lv1 2>&1 | tee out
|
||||||
grep "WARNING: Disabling lvmetad cache" out
|
grep "WARNING: Disabling lvmetad cache" out
|
||||||
|
|
||||||
pvs 2>&1 | tee out
|
pvs -vvvv 2>&1 | tee out
|
||||||
grep "$dev1" out
|
grep "$dev1" out
|
||||||
grep "$dev2" out
|
grep "$dev2" out
|
||||||
grep "WARNING: Not using lvmetad" out
|
grep "WARNING: Not using lvmetad" out
|
||||||
@ -56,7 +69,8 @@ grep $vg1 out
|
|||||||
grep $vg2 out
|
grep $vg2 out
|
||||||
grep "WARNING: Not using lvmetad" out
|
grep "WARNING: Not using lvmetad" out
|
||||||
|
|
||||||
vgremove $vg1 2>&1 | tee out
|
vgchange -an $vg1
|
||||||
|
vgremove -y $vg1 2>&1 | tee out
|
||||||
grep "WARNING: Not using lvmetad" out
|
grep "WARNING: Not using lvmetad" out
|
||||||
|
|
||||||
pvremove "$dev1" 2>&1 | tee out
|
pvremove "$dev1" 2>&1 | tee out
|
||||||
|
@ -1,48 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
# Copyright (C) 2007 Red Hat, Inc. All rights reserved.
|
|
||||||
#
|
|
||||||
# This copyrighted material is made available to anyone wishing to use,
|
|
||||||
# modify, copy, or redistribute it subject to the terms and conditions
|
|
||||||
# of the GNU General Public License v.2.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program; if not, write to the Free Software Foundation,
|
|
||||||
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
|
|
||||||
# lvmetad does not handle pool labels so skip test.
|
|
||||||
SKIP_WITH_LVMLOCKD=1
|
|
||||||
SKIP_WITH_LVMETAD=1
|
|
||||||
SKIP_WITH_LVMPOLLD=1
|
|
||||||
|
|
||||||
. lib/inittest
|
|
||||||
|
|
||||||
env printf "" || skip # skip if printf is not available
|
|
||||||
|
|
||||||
# create the old GFS pool labeled linear devices
|
|
||||||
create_pool_label_()
|
|
||||||
{
|
|
||||||
# FIXME
|
|
||||||
# echo -e is bashism, dash builtin sh doesn't do \xNN in printf either
|
|
||||||
# printf comes from coreutils, and is probably not posix either
|
|
||||||
env printf "\x01\x16\x70\x06\x5f\xcf\xff\xb9\xf8\x24\x8apool1" | dd of="$2" bs=5 seek=1 conv=notrunc
|
|
||||||
env printf "\x04\x01\x03\x00\x00\x00\x01\x00\x00\x00\x00\x00\x00\x00\x02\x00\x00\x00\x0$1\x68\x01\x16\x70\x00\x00\x00\x00\x00\x06\x5f\xd0" | dd of=$2 bs=273 seek=1 conv=notrunc
|
|
||||||
aux notify_lvmetad "$2"
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
aux prepare_devs 2
|
|
||||||
|
|
||||||
create_pool_label_ 0 "$dev1"
|
|
||||||
create_pool_label_ 1 "$dev2"
|
|
||||||
|
|
||||||
# check that pvcreate fails without -ff on the pool device
|
|
||||||
not pvcreate "$dev1"
|
|
||||||
|
|
||||||
# check that vgdisplay and pvcreate -ff works with the pool device
|
|
||||||
vgdisplay --config 'global { locking_type = 0 }'
|
|
||||||
aux disable_dev "$dev2"
|
|
||||||
# FIXME! since pool1 cannot be opened, vgdisplay gives error... should we say
|
|
||||||
# "not" there instead, checking that it indeed does fail?
|
|
||||||
vgdisplay --config 'global { locking_type = 0 }' || true
|
|
||||||
pvcreate -ff -y "$dev1"
|
|
@ -68,10 +68,6 @@ vgcreate $vg "$dev1" "$dev2"
|
|||||||
not vgcreate $vg "$dev1" "$dev2"
|
not vgcreate $vg "$dev1" "$dev2"
|
||||||
vgremove -ff $vg
|
vgremove -ff $vg
|
||||||
|
|
||||||
#COMM 'vgcreate rejects MaxLogicalVolumes > 255'
|
|
||||||
not vgcreate --metadatatype 1 --maxlogicalvolumes 1024 $vg "$dev1" "$dev2" 2>err
|
|
||||||
grep "Number of volumes may not exceed 255" err
|
|
||||||
|
|
||||||
#COMM "vgcreate fails when the only pv has --metadatacopies 0"
|
#COMM "vgcreate fails when the only pv has --metadatacopies 0"
|
||||||
not vgcreate $vg "$dev3"
|
not vgcreate $vg "$dev3"
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user