#! /bin/bash # SPDX-License-Identifier: GPL-2.0 # Copyright (C) 2017 IBM Corporation. All Rights Reserved. # # FSQA Test No. 043 # # Test constant inode numbers on non-samefs setup # This is a variant of overlay/017 to test constant st_ino numbers for # non-samefs setup. # # This simple test demonstrates a known issue with overlayfs: # - stat file A shows inode number X # - modify A to trigger copy up # - stat file A shows inode number Y != X # # Also test if d_ino of readdir entries changes after copy up # and if inode numbers persist after rename, drop caches and # mount cycle. # seq=`basename $0` seqres=$RESULT_DIR/$seq echo "QA output created by $seq" here=`pwd` tmp=/tmp/$$ status=1 # failure is the default! trap "_cleanup; exit \$status" 0 1 2 3 15 _cleanup() { cd / rm -f $tmp.* } # get standard environment, filters and checks . ./common/rc . ./common/filter # real QA test starts here _supported_fs overlay # Use non-default scratch underlying overlay dirs, we need to check # them explicity after test. _require_scratch_nocheck _require_test _require_test_program "af_unix" _require_test_program "t_dir_type" # Require redirect_dir for renaming a merge directory _require_scratch_feature redirect_dir rm -f $seqres.full lowerdir=$OVL_BASE_TEST_DIR/$seq-ovl-lower rm -rf $lowerdir mkdir $lowerdir # Create our test files. mkdir $lowerdir/dir touch $lowerdir/file ln -s $lowerdir/file $lowerdir/symlink mknod $lowerdir/chrdev c 1 1 mknod $lowerdir/blkdev b 1 1 mknod $lowerdir/fifo p $here/src/af_unix $lowerdir/socket _scratch_mkfs >>$seqres.full 2>&1 upperdir=$OVL_BASE_SCRATCH_MNT/$OVL_UPPER workdir=$OVL_BASE_SCRATCH_MNT/$OVL_WORK # Enable redirect_dir for renaming a merge directory. # Enabling xino in this test requires that base filesystem inode numbers will # not use bit 63 in inode number of the test files, because bit 63 is used by # overlayfs to indicate the layer. Let's just assume that this is true for all # tested filesystems and if we are wrong, the test may fail. _overlay_scratch_mount_dirs $lowerdir $upperdir $workdir -o redirect_dir=on,xino=on || \ _notrun "cannot mount overlay with xino=on option" _fs_options $SCRATCH_DEV | grep -q "xino=on" || \ _notrun "cannot enable xino feature" FILES="dir file symlink chrdev blkdev fifo socket" # Record inode numbers in format function record_inode_numbers() { dir=$1 outfile=$2 for f in $FILES; do ls -id $dir/$f done | \ while read ino file; do echo $ino `basename $file` >> $outfile done } # Check inode numbers match recorder inode numbers function check_inode_numbers() { dir=$1 before=$2 after=$3 record_inode_numbers $dir $after # Test constant stat(2) st_ino - # Compare before..after - expect silence # We use diff -u so out.bad will tell us which stage failed diff -u $before $after # Test constant readdir(3)/getdents(2) d_ino - # Expect to find file by inode number cat $before | while read ino f; do $here/src/t_dir_type $dir $ino | grep -q $f || \ echo "$f not found by ino $ino (from $before)" done } rm -f $tmp.* testdir=$SCRATCH_MNT/test mkdir -p $testdir # Record inode numbers before copy up record_inode_numbers $SCRATCH_MNT $tmp.before for f in $FILES; do # chown -h modifies all those file types chown -h 100 $SCRATCH_MNT/$f done # Compare inode numbers before/after copy up check_inode_numbers $SCRATCH_MNT $tmp.before $tmp.after_copyup for f in $FILES; do # move to another dir mv $SCRATCH_MNT/$f $testdir/ done echo 3 > /proc/sys/vm/drop_caches # Compare inode numbers before/after rename and drop caches check_inode_numbers $testdir $tmp.after_copyup $tmp.after_move # Verify that the inode numbers survive a mount cycle $UMOUNT_PROG $SCRATCH_MNT _overlay_scratch_mount_dirs $lowerdir $upperdir $workdir -o redirect_dir=on,xino=on # Compare inode numbers before/after mount cycle check_inode_numbers $testdir $tmp.after_move $tmp.after_cycle # check overlayfs _overlay_check_scratch_dirs $lowerdir $upperdir $workdir -o redirect_dir=on,xino=on echo "Silence is golden" status=0 exit