xref: /dflybsd-src/contrib/lvm2/dist/test/t-pvcreate-operation-md.sh (revision 86d7f5d305c6adaa56ff4582ece9859d73106103)
186d7f5d3SJohn Marino# Copyright (C) 2009 Red Hat, Inc. All rights reserved.
286d7f5d3SJohn Marino#
386d7f5d3SJohn Marino# This copyrighted material is made available to anyone wishing to use,
486d7f5d3SJohn Marino# modify, copy, or redistribute it subject to the terms and conditions
586d7f5d3SJohn Marino# of the GNU General Public License v.2.
686d7f5d3SJohn Marino#
786d7f5d3SJohn Marino# You should have received a copy of the GNU General Public License
886d7f5d3SJohn Marino# along with this program; if not, write to the Free Software Foundation,
986d7f5d3SJohn Marino# Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
1086d7f5d3SJohn Marino
1186d7f5d3SJohn Marino# skip this test if mdadm or sfdisk (or others) aren't available
1286d7f5d3SJohn Marinowhich mdadm || exit 200
1386d7f5d3SJohn Marinowhich sfdisk || exit 200
1486d7f5d3SJohn Marinowhich perl || exit 200
1586d7f5d3SJohn Marinowhich awk || exit 200
1686d7f5d3SJohn Marinowhich cut || exit 200
1786d7f5d3SJohn Marinotest -f /proc/mdstat || exit 200
1886d7f5d3SJohn Marino
1986d7f5d3SJohn Marino. ./test-utils.sh
2086d7f5d3SJohn Marino
2186d7f5d3SJohn Marinoprepare_lvmconf '[ "a|/dev/md.*|", "a/dev\/mapper\/.*$/", "r/.*/" ]'
2286d7f5d3SJohn Marinoaux prepare_devs 2
2386d7f5d3SJohn Marino
2486d7f5d3SJohn Marino# Have MD use a non-standard name to avoid colliding with an existing MD device
2586d7f5d3SJohn Marino# - mdadm >= 3.0 requires that non-standard device names be in /dev/md/
2686d7f5d3SJohn Marino# - newer mdadm _completely_ defers to udev to create the associated device node
2786d7f5d3SJohn Marinomdadm_maj=$(mdadm --version 2>&1 | perl -pi -e 's|.* v(\d+).*|\1|')
2886d7f5d3SJohn Marino[ $mdadm_maj -ge 3 ] && \
2986d7f5d3SJohn Marino    mddev=/dev/md/md_lvm_test0 || \
3086d7f5d3SJohn Marino    mddev=/dev/md_lvm_test0
3186d7f5d3SJohn Marino
3286d7f5d3SJohn Marinocleanup_md() {
3386d7f5d3SJohn Marino    # sleeps offer hack to defeat: 'md: md127 still in use'
3486d7f5d3SJohn Marino    # see: https://bugzilla.redhat.com/show_bug.cgi?id=509908#c25
3586d7f5d3SJohn Marino    sleep 2
3686d7f5d3SJohn Marino    mdadm --stop $mddev
3786d7f5d3SJohn Marino    if [ -b "$mddev" ]; then
3886d7f5d3SJohn Marino        # mdadm doesn't always cleanup the device node
3986d7f5d3SJohn Marino	sleep 2
4086d7f5d3SJohn Marino	rm -f $mddev
4186d7f5d3SJohn Marino    fi
4286d7f5d3SJohn Marino    teardown_
4386d7f5d3SJohn Marino}
4486d7f5d3SJohn Marino
4586d7f5d3SJohn Marino# create 2 disk MD raid0 array (stripe_width=128K)
4686d7f5d3SJohn Marino[ -b "$mddev" ] && exit 200
4786d7f5d3SJohn Marinomdadm --create $mddev --auto=md --level 0 --raid-devices=2 --chunk 64 $dev1 $dev2
4886d7f5d3SJohn Marinotrap 'aux cleanup_md' EXIT # cleanup this MD device at the end of the test
4986d7f5d3SJohn Marino
5086d7f5d3SJohn Marino# Test alignment of PV on MD without any MD-aware or topology-aware detection
5186d7f5d3SJohn Marino# - should treat $mddev just like any other block device
5286d7f5d3SJohn Marinopv_align="192.00k"
5386d7f5d3SJohn Marinopvcreate --metadatasize 128k \
5486d7f5d3SJohn Marino    --config 'devices {md_chunk_alignment=0 data_alignment_detection=0 data_alignment_offset_detection=0}' \
5586d7f5d3SJohn Marino    $mddev
5686d7f5d3SJohn Marinocheck_pv_field_ $mddev pe_start $pv_align
5786d7f5d3SJohn Marino
5886d7f5d3SJohn Marino# Test md_chunk_alignment independent of topology-aware detection
5986d7f5d3SJohn Marinopv_align="256.00k"
6086d7f5d3SJohn Marinopvcreate --metadatasize 128k \
6186d7f5d3SJohn Marino    --config 'devices {data_alignment_detection=0 data_alignment_offset_detection=0}' \
6286d7f5d3SJohn Marino    $mddev
6386d7f5d3SJohn Marinocheck_pv_field_ $mddev pe_start $pv_align
6486d7f5d3SJohn Marino
6586d7f5d3SJohn Marino# Get linux minor version
6686d7f5d3SJohn Marinolinux_minor=$(echo `uname -r` | cut -d'.' -f3 | cut -d'-' -f1)
6786d7f5d3SJohn Marino
6886d7f5d3SJohn Marino# Test newer topology-aware alignment detection
6986d7f5d3SJohn Marinoif [ $linux_minor -gt 31 ]; then
7086d7f5d3SJohn Marino    pv_align="256.00k"
7186d7f5d3SJohn Marino    pvcreate --metadatasize 128k \
7286d7f5d3SJohn Marino	--config 'devices { md_chunk_alignment=0 }' $mddev
7386d7f5d3SJohn Marino    check_pv_field_ $mddev pe_start $pv_align
7486d7f5d3SJohn Marinofi
7586d7f5d3SJohn Marino
7686d7f5d3SJohn Marino# partition MD array directly, depends on blkext in Linux >= 2.6.28
7786d7f5d3SJohn Marinoif [ $linux_minor -gt 27 ]; then
7886d7f5d3SJohn Marino    # create one partition
7986d7f5d3SJohn Marino    sfdisk $mddev <<EOF
8086d7f5d3SJohn Marino,,83
8186d7f5d3SJohn MarinoEOF
8286d7f5d3SJohn Marino    # make sure partition on MD is _not_ removed
8386d7f5d3SJohn Marino    # - tests partition -> parent lookup via sysfs paths
8486d7f5d3SJohn Marino    not pvcreate --metadatasize 128k $mddev
8586d7f5d3SJohn Marino
8686d7f5d3SJohn Marino    # verify alignment_offset is accounted for in pe_start
8786d7f5d3SJohn Marino    # - topology infrastructure is available in Linux >= 2.6.31
8886d7f5d3SJohn Marino    # - also tests partition -> parent lookup via sysfs paths
8986d7f5d3SJohn Marino
9086d7f5d3SJohn Marino    # Oh joy: need to lookup /sys/block/md127 rather than /sys/block/md_lvm_test0
9186d7f5d3SJohn Marino    mddev_maj_min=$(ls -lL $mddev | awk '{ print $5 $6 }' | perl -pi -e 's|,|:|')
9286d7f5d3SJohn Marino    mddev_p_sysfs_name=$(echo /sys/dev/block/${mddev_maj_min}/*p1)
9386d7f5d3SJohn Marino    base_mddev_p=`basename $mddev_p_sysfs_name`
9486d7f5d3SJohn Marino    mddev_p=/dev/${base_mddev_p}
9586d7f5d3SJohn Marino
9686d7f5d3SJohn Marino    # Checking for 'alignment_offset' in sysfs implies Linux >= 2.6.31
9786d7f5d3SJohn Marino    sysfs_alignment_offset=/sys/dev/block/${mddev_maj_min}/${base_mddev_p}/alignment_offset
9886d7f5d3SJohn Marino    [ -f $sysfs_alignment_offset ] && \
9986d7f5d3SJohn Marino	alignment_offset=`cat $sysfs_alignment_offset` || \
10086d7f5d3SJohn Marino	alignment_offset=0
10186d7f5d3SJohn Marino
10286d7f5d3SJohn Marino    if [ "$alignment_offset" = "512" ]; then
10386d7f5d3SJohn Marino	pv_align="256.50k"
10486d7f5d3SJohn Marino	pvcreate --metadatasize 128k $mddev_p
10586d7f5d3SJohn Marino	check_pv_field_ $mddev_p pe_start $pv_align
10686d7f5d3SJohn Marino	pvremove $mddev_p
10786d7f5d3SJohn Marino    elif [ "$alignment_offset" = "2048" ]; then
10886d7f5d3SJohn Marino	pv_align="258.00k"
10986d7f5d3SJohn Marino	pvcreate --metadatasize 128k $mddev_p
11086d7f5d3SJohn Marino	check_pv_field_ $mddev_p pe_start $pv_align
11186d7f5d3SJohn Marino	pvremove $mddev_p
11286d7f5d3SJohn Marino    fi
11386d7f5d3SJohn Marinofi
114