Re: [RFC PATCH] fstests: add support for hfsplus

[Date Prev] [Date Next] [Thread Prev] [Thread Next] [Date Index] [Thread Index]



On Sun, Sep 02, 2018 at 01:09:57AM +0800, Eryu Guan wrote:
> On Fri, Aug 31, 2018 at 11:05:03PM -0300, Ernesto A. Fernández wrote:
> > It is not possible to set file system size when running mkfs.hfsplus,
> > so use the device mapper as a workaround.
> 
> I'd prefer _notrun the test in _scratch_mkfs_sized() instead of this
> workaround, as the harness is expecting to operate $SCRATCH_DEV but this
> workaround may break this assumption in subtle ways, e.g. now
> _check_scratch_fs fails to create hfsplus-tmp device because
> $SCRATCH_DEV may still be mounted.

I didn't realize $SCRATCH_DEV could still be mounted, sorry. Maybe I can
unmount it before _dmsetup_create(), and remount after _dmsetup_remove()?
Like _check_generic_filesystem() does. Or would that bring other problems?

I know it's ugly, but one test that uses _scratch_mkfs_sized() has helped
me find a number of bugs already. It would be really useful to get it to
work.

Thanks,
Ernest

> 
> Otherwise this patch looks fine to me.
> 
> Thanks,
> Eryu
> 
> > 
> > Signed-off-by: Ernesto A. Fernández <ernesto.mnd.fernandez@xxxxxxxxx>
> > ---
> > I've been using this to test hfsplus patches. If there's a better way
> > please let me know.
> > 
> >  common/config |  7 +++++++
> >  common/rc     | 38 +++++++++++++++++++++++++++++++++++++-
> >  2 files changed, 44 insertions(+), 1 deletion(-)
> > 
> > diff --git a/common/config b/common/config
> > index 2f1f2720..32a1ccb8 100644
> > --- a/common/config
> > +++ b/common/config
> > @@ -229,6 +229,7 @@ case "$HOSTOS" in
> >  	export MKFS_CIFS_PROG="false"
> >  	export MKFS_OVERLAY_PROG="false"
> >  	export MKFS_REISER4_PROG=$(type -P mkfs.reiser4)
> > +	export MKFS_HFSPLUS_PROG=$(type -P mkfs.hfsplus)
> >  	export E2FSCK_PROG=$(type -P e2fsck)
> >  	export TUNE2FS_PROG=$(type -P tune2fs)
> >  	export FSCK_OVERLAY_PROG=$(type -P fsck.overlay)
> > @@ -313,6 +314,9 @@ _mount_opts()
> >  	ubifs)
> >  		export MOUNT_OPTIONS=$UBIFS_MOUNT_OPTIONS
> >  		;;
> > +	hfsplus)
> > +		export MOUNT_OPTIONS=$HFSPLUS_MOUNT_OPTIONS
> > +		;;
> >  	*)
> >  		;;
> >  	esac
> > @@ -380,6 +384,9 @@ _mkfs_opts()
> >  	f2fs)
> >  		export MKFS_OPTIONS="$F2FS_MKFS_OPTIONS"
> >  		;;
> > +	hfsplus)
> > +		export MKFS_OPTIONS=$HFSPLUS_MKFS_OPTIONS
> > +		;;
> >  	*)
> >  		;;
> >  	esac
> > diff --git a/common/rc b/common/rc
> > index ec631ad9..38f61944 100644
> > --- a/common/rc
> > +++ b/common/rc
> > @@ -158,6 +158,9 @@ case "$FSTYP" in
> >      ubifs)
> >  	[ "$UBIUPDATEVOL_PROG" = "" ] && _fatal "ubiupdatevol not found"
> >  	;;
> > +    hfsplus)
> > +	 [ "$MKFS_HFSPLUS_PROG" = "" ] && _fatal "mkfs.hfsplus not found"
> > +	 ;;
> >  esac
> >  
> >  if [ ! -z "$REPORT_LIST" ]; then
> > @@ -746,6 +749,12 @@ _scratch_mkfs()
> >  		mkfs_cmd="yes | $MKFS_PROG -t $FSTYP --"
> >  		mkfs_filter="grep -v -e ^mkfs\.ocfs2"
> >  		;;
> > +	hfsplus)
> > +		mkfs_cmd="yes | $MKFS_PROG -t $FSTYP --"
> > +		mkfs_filter="cat"
> > +		# a test may have been interrupted after _scratch_mkfs_sized()
> > +		rm -f ${RESULT_DIR}/hfsplus_sectors
> > +		;;
> >  	*)
> >  		mkfs_cmd="yes | $MKFS_PROG -t $FSTYP --"
> >  		mkfs_filter="cat"
> > @@ -995,6 +1004,17 @@ _scratch_mkfs_sized()
> >  	fi
> >  	export MOUNT_OPTIONS="-o size=$fssize $TMPFS_MOUNT_OPTIONS"
> >  	;;
> > +    hfsplus)
> > +	# mkfs.hfsplus does not allow setting the size of the filesystem
> > +	_require_dm_target linear
> > +	local sectors=`expr $fssize / 512`
> > +	local table="0 $sectors linear $SCRATCH_DEV 0"
> > +	_dmsetup_create hfsplus-tmp --table "$table" || _fatal "dmsetup failed"
> > +	${MKFS_PROG}.$FSTYP $MKFS_OPTIONS -b $blocksize /dev/mapper/hfsplus-tmp
> > +	_dmsetup_remove hfsplus-tmp
> > +	# remember the true size of the filesystem for fsck.hfsplus
> > +	echo -n $sectors > ${RESULT_DIR}/hfsplus_sectors
> > +	;;
> >      *)
> >  	_notrun "Filesystem $FSTYP not supported in _scratch_mkfs_sized"
> >  	;;
> > @@ -2661,6 +2681,22 @@ _check_scratch_fs()
> >      ubifs)
> >  	# there is no fsck program for ubifs yet
> >  	;;
> > +    hfsplus)
> > +	# fsck.hfsplus will always assume the filesystem fills the device
> > +	if [ -f ${RESULT_DIR}/hfsplus_sectors ]; then
> > +	    local sectors=`cat ${RESULT_DIR}/hfsplus_sectors`
> > +	    rm -f ${RESULT_DIR}/hfsplus_sectors
> > +	    local table="0 $sectors linear $SCRATCH_DEV 0"
> > +	    _dmsetup_create hfsplus-tmp --table "$table" || \
> > +						_fatal "dmsetup failed"
> > +	    _check_generic_filesystem /dev/mapper/hfsplus-tmp
> > +	    local fsck_status=$?
> > +	    _dmsetup_remove hfsplus-tmp
> > +	    return $fsck_status
> > +	else
> > +	    _check_generic_filesystem $device
> > +	fi
> > +	;;
> >      *)
> >  	_check_generic_filesystem $device
> >  	;;
> > @@ -3055,7 +3091,7 @@ _require_metadata_journaling()
> >  	fi
> >  
> >  	case "$FSTYP" in
> > -	ext2|vfat|msdos|udf)
> > +	ext2|vfat|msdos|udf|hfsplus)
> >  		_notrun "$FSTYP does not support metadata journaling"
> >  		;;
> >  	ext4)
> > -- 
> > 2.11.0
> > 



[Index of Archives]     [Linux Filesystems Development]     [Linux NFS]     [Linux NILFS]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux