Training courses

Kernel and Embedded Linux

Bootlin training courses

Embedded Linux, kernel,
Yocto Project, Buildroot, real-time,
graphics, boot time, debugging...

Bootlin logo

Elixir Cross Referencer

##	$NetBSD: Makefile,v 1.7 2014/01/16 01:15:33 christos Exp $
##  Notes:
##    This set of tests creates a dummy directory tree in /tmp and
##    populates it with several files.  The test requires around 1100
##    inodes and 6.8MB. The test system needs to run a kernel with
##    FFS Endian Independent support (options FFS_EI) to be able to
##    perform this test.
##
##    This test verifies that newfs can create filesystems in both bytes
##    orders. For each byte order it is checked that:
##      - the kernel understands both filesystems created
##      - fsck_ffs can convert them from one byte order to the other
##      - dump handles properly the 'nodump' flag, an that restore can
##        properly restore the filesystem.
##
##    This is derived from work done by Brian Grayson, submitted in PR 6706.

.include <bsd.own.mk>

TMPL=/tmp/ffstemplate
TMPMP=/tmp/ffsregresstest_mount
TMPIM=/var/tmp/ffsregresstest.im
TMPREST=/tmp/restoreregress
EN?= be
DIGITS=0 1 2 3 4 5 6 7 8 9

VND?= vnd0
BVND= /dev/${VND}
CVND= /dev/r${VND}
MPART?= a
.if (${MACHINE_ARCH} == "i386")
RPART?= d
.else
RPART?= c
.endif

# As make is called recusively, and we may cd to ${OBJDIR}, we need to call make
# with some variables propagated.
SRCDIR?= ${.CURDIR}
MAKECMD= ${MAKE} -f ${SRCDIR}/Makefile SRCDIR=${SRCDIR} EN=${EN} VND=${VND} MPART=${MPART} RPART=${RPART}

regress: template
	${MAKECMD} EN=be makeregress
	${MAKECMD} clean-tmpfs
	${MAKECMD} EN=le makeregress
	${MAKECMD} clean

makeregress: tmpfs
	${MAKECMD} dump
	${MAKECMD} fsck
	${MAKECMD} clean-dump;

clean: clean-tmpfs clean-template clean-dump
clean-dump:
	@echo "***  Cleaning up ${TMPREST}."
	-rm -rf ${TMPREST}
clean-tmpfs:
	@echo "***  Cleaning up ${TMPMP}."
	-umount ${TMPMP}
	-vnconfig -u ${BVND}${RPART}
	-rm -rf ${TMPMP} ${TMPIM}
clean-template:
	@echo "***  Cleaning up ${TMPL}."
	-rm -rf ${TMPL}

cmp:
	diff -r -q ${TMPL} ${TMPMP}

dump:
	@echo "***  Testing dump nodump flag support."
	@#  First of all, estimate the size of a dump of just the tmpfs.
	${HOST_SH} ${SRCDIR}/estimatecompare 2572 -S -h9 -0 ${CVND}${MPART}

	@#  Now estimate the size, after honoring the nodump flag.
	${HOST_SH} ${SRCDIR}/estimatecompare 347  -S -h0 -0 ${CVND}${MPART}
	@echo "***  Testing dump/restore support"
	mkdir ${TMPREST}
	dump -0 -h9 -B10000 -f - ${CVND}${MPART} | \
	    (cd ${TMPREST}; restore -rf -)
	@#restore should have created a restoresymtable file
	rm ${TMPREST}/restoresymtable
	diff -r -q ${TMPL} ${TMPREST}

fsck:
	@echo "*** checking fsck_ffs endian conversion."
	umount ${BVND}${MPART}
.if (${EN} == le)
	fsck_ffs -B be -y ${CVND}${MPART}
	mount -o async ${BVND}${MPART} ${TMPMP}
	${MAKECMD} cmp
	umount ${BVND}${MPART}
	fsck_ffs -B le -y ${CVND}${MPART}
	mount -o async ${BVND}${MPART} ${TMPMP}
	${MAKECMD} cmp
.else
	fsck_ffs -B le -y ${CVND}${MPART}
	mount -o async ${BVND}${MPART} ${TMPMP}
	${MAKECMD} cmp
	umount ${BVND}${MPART}
	fsck_ffs -B be -y ${CVND}${MPART}
	mount -o async ${BVND}${MPART} ${TMPMP}
	${MAKECMD} cmp
.endif

tmpfs:
	@echo "***  Creating a dummy directory tree at ${TMPMP} monted on" \
	    "${TMPIM}, ${EN} byte order."
	dd if=/dev/zero of=${TMPIM} count=5860
	vnconfig -v ${BVND}${RPART} ${TMPIM}
	disklabel -f ${SRCDIR}/disktab -rw ${VND} floppy288
	newfs -B ${EN} -i 500 -b 8192 -f 1024 ${CVND}${MPART}
	mkdir ${TMPMP}
	mount -o async ${BVND}${MPART} ${TMPMP}
	# Arg, cp will give an error if the symlink is copied before its target
	-cp -Rp ${TMPL}/* ${TMPMP}
	${MAKECMD} cmp

template:
	mkdir ${TMPL}
	@# Create a directory with a 10K file, with the file marked nodump.
	mkdir ${TMPL}/nodumpfile
	jot -r -c -s '' -n 10240 > ${TMPL}/nodumpfile/10k 
	chflags nodump ${TMPL}/nodumpfile/10k
	@# And some ordinary 10k files.
	mkdir ${TMPL}/dumpfile
	TMPFS_DUMP=${TMPL}/dumpfile/dumpfile.10k; \
	for f in ${DIGITS}; do \
	  jot -r -c -s '' -n 10240 > $$TMPFS_DUMP.$$f; done;
	@# A subdir with a short and a long symbolic link in it
	mkdir ${TMPL}/dumpfile/subdir
	ln -s ../dumpfile.10k.0 ${TMPL}/dumpfile/subdir/link;
	ln -s ../dumpfile.10k.1 ${TMPL}/dumpfile/subdir/really_really_really_really_really_really_long_name_to_use_up_space.link;
	@# And now the same files, but in a dir marked nodump:
	mkdir ${TMPL}/nodumpdir
	chflags nodump ${TMPL}/nodumpdir
	TMPFS_1=${TMPL}/nodumpdir/10k; \
	  for f in ${DIGITS}; do  \
	      jot -r -c -s '' -n 10240 > $$TMPFS_1.$$f; \
	  done
	
	@# Also create a large directory that uses more than one direct block
	@# (so it has to be larger than 8K).
	@# Make sure one entry is for a deleted file, also.
	mkdir ${TMPL}/2blkdir
	TMPFS_1=${TMPL}/2blkdir; \
	  jot -r -c -s '' -n 10 > $$TMPFS_1/10b; \
	  for f in ${DIGITS}; do for g in ${DIGITS}; do \
	    jot -r -c -s '' -n 10 > \
	      $$TMPFS_1/really_really_really_really_really_really_long_name_to_use_up_space_$$f$$g ;\
	    done; done; \
	  rm $$TMPFS_1/10b

	@# Now create a directory with at least one indirect block.
	@# On a FS with 8K blocks, we need at least 1 + 12*8192 bytes, or
	@#   98305 bytes, in the directory.  1000 files does the trick,
	@#   with the long filename below.
	mkdir ${TMPL}/indirblk
	chflags nodump ${TMPL}/indirblk
	TMPFS_1=${TMPL}/indirblk; \
	  jot -r -c -s '' -n 10 >  $$TMPFS_1/10b; \
	  for e in 0; do\
	  for f in ${DIGITS}; do for g in ${DIGITS}; do for h in ${DIGITS}; do \
	    jot -r -c -s '' -n 10 >  \
	      $$TMPFS_1/really_really_really_really_really_really_long_name_to_use_up_dir_entry_space$$e$$f$$g$$h ;\
	    done; done; done; done; \
	  rm $$TMPFS_1/10b
	@# ^---  As before, make sure at least one direntry is a deleted file.