1
0
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:
Joe Thornber 2018-05-01 20:04:30 +01:00
commit db0560c1b0
5 changed files with 36 additions and 60 deletions

View File

@ -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);
} }

View File

@ -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;

View File

@ -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

View File

@ -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"

View File

@ -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"