xref: /netbsd-src/tests/fs/lfs/t_pr.c (revision 36592171e1e530a304af869297e5cfe5d9c2fd1f)
1*36592171Smaya /*	$NetBSD: t_pr.c,v 1.8 2019/07/09 16:24:01 maya Exp $	*/
261ee6255Spooka 
361ee6255Spooka #include <sys/types.h>
461ee6255Spooka #include <sys/mount.h>
561ee6255Spooka 
661ee6255Spooka #include <atf-c.h>
761ee6255Spooka #include <errno.h>
861ee6255Spooka #include <fcntl.h>
961ee6255Spooka #include <limits.h>
1061ee6255Spooka #include <stdio.h>
1161ee6255Spooka #include <stdlib.h>
1261ee6255Spooka #include <unistd.h>
1361ee6255Spooka #include <string.h>
1461ee6255Spooka 
1561ee6255Spooka #include <rump/rump.h>
1661ee6255Spooka #include <rump/rump_syscalls.h>
1761ee6255Spooka 
1861ee6255Spooka #include <ufs/ufs/ufsmount.h>
1961ee6255Spooka 
20c54cb811Schristos #include "h_macros.h"
2161ee6255Spooka 
2261ee6255Spooka ATF_TC(mknod);
ATF_TC_HEAD(mknod,tc)2361ee6255Spooka ATF_TC_HEAD(mknod, tc)
2461ee6255Spooka {
2561ee6255Spooka 
2661ee6255Spooka 	atf_tc_set_md_var(tc, "descr", "mknod(2) hangs on LFS (PR kern/43503)");
2702b6060dSpooka 	atf_tc_set_md_var(tc, "timeout", "20");
2861ee6255Spooka }
2961ee6255Spooka 
3061ee6255Spooka #define IMGNAME "disk.img"
3161ee6255Spooka #define FAKEBLK "/dev/blk"
ATF_TC_BODY(mknod,tc)3261ee6255Spooka ATF_TC_BODY(mknod, tc)
3361ee6255Spooka {
3461ee6255Spooka 	struct ufs_args args;
3561ee6255Spooka 
3661ee6255Spooka 	/* hmm, maybe i should fix newfs_lfs instead? */
3761ee6255Spooka 	if (system("newfs_lfs -D -F -s 10000 ./" IMGNAME) == -1)
3861ee6255Spooka 		atf_tc_fail_errno("newfs failed");
3961ee6255Spooka 
4061ee6255Spooka 	memset(&args, 0, sizeof(args));
4161ee6255Spooka 	args.fspec = __UNCONST(FAKEBLK);
4261ee6255Spooka 
4361ee6255Spooka 	rump_init();
4461ee6255Spooka 	if (rump_sys_mkdir("/mp", 0777) == -1)
4561ee6255Spooka 		atf_tc_fail_errno("cannot create mountpoint");
4661ee6255Spooka 	rump_pub_etfs_register(FAKEBLK, IMGNAME, RUMP_ETFS_BLK);
4761ee6255Spooka 	if (rump_sys_mount(MOUNT_LFS, "/mp", 0, &args, sizeof(args)) == -1)
4861ee6255Spooka 		atf_tc_fail_errno("rump_sys_mount failed");
4961ee6255Spooka 
5056e49f7fSjmmv 	//atf_tc_expect_timeout("PR kern/43503");
5161ee6255Spooka 	if (rump_sys_mknod("/mp/node", S_IFCHR | 0777, 0) == -1)
5261ee6255Spooka 		atf_tc_fail_errno("mknod failed");
5361ee6255Spooka }
5461ee6255Spooka 
ATF_TP_ADD_TCS(tp)5561ee6255Spooka ATF_TP_ADD_TCS(tp)
5661ee6255Spooka {
5761ee6255Spooka 
5861ee6255Spooka 	ATF_TP_ADD_TC(tp, mknod);
59*36592171Smaya 	return atf_no_error();
6061ee6255Spooka }
61