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