mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-02 01:18:26 +03:00
39cc12e7c2
Change the test to use 'zero' backend, so we could use larger size and get 'larger' buffer of dirty blocks for fast CPUs...
90 lines
2.8 KiB
Bash
90 lines
2.8 KiB
Bash
#!/usr/bin/env bash
|
|
|
|
# Copyright (C) 2017 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
|
|
|
|
# Exercise cache flushing is abortable
|
|
|
|
|
|
SKIP_WITH_LVMPOLLD=1
|
|
|
|
. lib/inittest
|
|
|
|
aux have_cache 1 3 0 || skip
|
|
|
|
aux prepare_vg
|
|
|
|
SIZE_MB=200
|
|
|
|
# Use large zero device and later delayed metadata dev1
|
|
lvcreate -L$((SIZE_MB * 2))M --type zero -n cpool $vg
|
|
lvconvert -y --type cache-pool --chunksize 32k $vg/cpool "$dev1"
|
|
lvcreate -L$((SIZE_MB * 2))M --type zero -n $lv1 $vg
|
|
lvconvert -y -H --chunksize 32k --cachemode writeback --cachepool $vg/cpool $vg/$lv1
|
|
|
|
#
|
|
# Ensure cache gets promoted blocks
|
|
#
|
|
for i in $(seq 1 2) ; do
|
|
dd if=/dev/zero of="$DM_DEV_DIR/$vg/$lv1" bs=1M count=$SIZE_MB oflag=direct || true
|
|
dd if="$DM_DEV_DIR/$vg/$lv1" of=/dev/null bs=1M count=$SIZE_MB iflag=direct || true
|
|
done
|
|
|
|
aux delay_dev "$dev1" 0 200 "$(get first_extent_sector "$dev1"):"
|
|
dd if=/dev/zero of="$DM_DEV_DIR/$vg/$lv1" bs=1M count=$SIZE_MB
|
|
|
|
lvdisplay --maps $vg
|
|
# Delay dev to ensure we have some time to 'capture' interrupt in flush
|
|
|
|
# TODO, how to make writeback cache dirty
|
|
test "$(get lv_field $vg/$lv1 cache_dirty_blocks)" -gt 0 || {
|
|
lvdisplay --maps $vg
|
|
skip "Cannot make a dirty writeback cache LV."
|
|
}
|
|
|
|
LVM_TEST_TAG="kill_me_$PREFIX" lvconvert -vvvv --splitcache $vg/$lv1 >logconvert 2>&1 &
|
|
PID_CONVERT=$!
|
|
for i in {1..50}; do
|
|
out=$(dmsetup status --noflush "$vg-$lv1")
|
|
case "$out" in
|
|
*cleaner*) break;;
|
|
esac
|
|
echo "$i: Waiting for cleaner policy on $vg/$lv1"
|
|
sleep .01
|
|
done
|
|
test "$i" -ge 49 && die "Waited for cleaner policy on $vg/$lv1 too long!"
|
|
|
|
# While lvconvert updated table to 'cleaner' policy now it
|
|
# should be running in 'Flushing' loop and just 1 KILL should
|
|
# cause abortion of flushing
|
|
kill -INT $PID_CONVERT
|
|
aux enable_dev "$dev2"
|
|
wait
|
|
#cat logconvert || true
|
|
|
|
# Problem of this test is, in older kernels, even the initial change to cleaner
|
|
# policy table line causes long suspend which in practice is cleaning all the
|
|
# dirty blocks - so the test can't really break the cache clearing.
|
|
#
|
|
# So the failure of test is reported only for recent kernels > 5.6
|
|
# ans skipped otherwise - as those can't be fixed anyway
|
|
grep -E "Flushing.*aborted" logconvert || {
|
|
cat logconvert || true
|
|
vgremove -f $vg
|
|
aux kernel_at_least 5 6 || skip "Cache missed to abort flushing with older kernel"
|
|
die "Flushing of $vg/$lv1 not aborted ?"
|
|
}
|
|
|
|
# check the table got restored
|
|
check grep_dmsetup table $vg-$lv1 "writeback"
|
|
lvdisplay --maps $vg
|
|
|
|
vgremove -f $vg
|