1272343Sngie/*	$NetBSD: t_mount.c,v 1.13 2012/11/27 16:01:49 jakllsch Exp $	*/
2272343Sngie
3272343Sngie/*
4272343Sngie * Basic tests for mounting
5272343Sngie */
6272343Sngie
7272343Sngie/*
8272343Sngie * 48Kimage:
9272343Sngie * Adapted for rump and atf from a testcase supplied
10272343Sngie * by Hubert Feyrer on netbsd-users@
11272343Sngie */
12272343Sngie
13272343Sngie#include <atf-c.h>
14272343Sngie
15272343Sngie#define FSTEST_IMGSIZE (96 * 512)
16272343Sngie#include "../common/h_fsmacros.h"
17272343Sngie
18272343Sngie#include <sys/types.h>
19272343Sngie#include <sys/mount.h>
20272343Sngie
21272343Sngie#include <stdlib.h>
22272343Sngie
23272343Sngie#include <ufs/ufs/ufsmount.h>
24272343Sngie
25272343Sngie#include <rump/rump.h>
26272343Sngie#include <rump/rump_syscalls.h>
27272343Sngie
28272343Sngie#include "../../h_macros.h"
29272343Sngie
30272343SngieATF_TC(48Kimage);
31272343SngieATF_TC_HEAD(48Kimage, tc)
32272343Sngie{
33272343Sngie	atf_tc_set_md_var(tc, "descr", "mount small 48K ffs image");
34272343Sngie}
35272343Sngie
36272343SngieATF_TC_BODY(48Kimage, tc)
37272343Sngie{
38272343Sngie	void *tmp;
39272343Sngie
40272343Sngie	atf_tc_expect_fail("PR kern/43573");
41272343Sngie	FSTEST_CONSTRUCTOR(tc, ffs, tmp);
42272343Sngie	atf_tc_expect_pass();
43272343Sngie
44272343Sngie	FSTEST_DESTRUCTOR(tc, ffs, tmp);
45272343Sngie}
46272343Sngie
47272343SngieATF_TC(fsbsizeovermaxphys);
48272343SngieATF_TC_HEAD(fsbsizeovermaxphys, tc)
49272343Sngie{
50272343Sngie
51272343Sngie	atf_tc_set_md_var(tc, "descr", "mounts file system with "
52272343Sngie	    "blocksize > MAXPHYS");
53272343Sngie	/* PR kern/43727 */
54272343Sngie}
55272343Sngie
56272343SngieATF_TC_BODY(fsbsizeovermaxphys, tc)
57272343Sngie{
58272343Sngie	char cmd[1024];
59272343Sngie	struct ufs_args args;
60272343Sngie	struct statvfs svb;
61272343Sngie
62272343Sngie	/*
63272343Sngie	 * We cannot pass newfs parameters via the fstest interface,
64272343Sngie	 * so do things the oldfashioned manual way.
65272343Sngie	 */
66272343Sngie	snprintf(cmd, sizeof(cmd), "newfs -G -b %d -F -s 10000 "
67272343Sngie	    "ffs.img > /dev/null", MAXPHYS * 2);
68272343Sngie	if (system(cmd))
69272343Sngie		atf_tc_fail("cannot create file system");
70272343Sngie
71272343Sngie	rump_init();
72272343Sngie	if (rump_pub_etfs_register("/devdisk", "ffs.img", RUMP_ETFS_BLK))
73272343Sngie		atf_tc_fail("cannot register rump fake device");
74272343Sngie
75272343Sngie	args.fspec = __UNCONST("/devdisk");
76272343Sngie
77272343Sngie	if (rump_sys_mkdir("/mp", 0777) == -1)
78272343Sngie		atf_tc_fail_errno("create mountpoint");
79272343Sngie
80272343Sngie	/* mount succeeded?  bad omen.  confirm we're in trouble.  */
81272343Sngie	if (rump_sys_mount(MOUNT_FFS, "/mp", 0, &args, sizeof(args)) != -1) {
82272343Sngie		rump_sys_statvfs1("/mp", &svb, ST_WAIT);
83272343Sngie		atf_tc_fail("not expecting to be alive");
84272343Sngie	}
85272343Sngie
86272343Sngie	/* otherwise we're do-ne */
87272343Sngie}
88272343Sngie
89272343SngieATF_TC(fsbsizeovermaxbsize);
90272343SngieATF_TC_HEAD(fsbsizeovermaxbsize, tc)
91272343Sngie{
92272343Sngie
93272343Sngie	atf_tc_set_md_var(tc, "descr", "mounts file system with "
94272343Sngie	    "blocksize > MAXBSIZE");
95272343Sngie}
96272343Sngie
97272343SngieATF_TC_BODY(fsbsizeovermaxbsize, tc)
98272343Sngie{
99272343Sngie	char cmd[1024];
100272343Sngie	struct ufs_args args;
101272343Sngie	struct statvfs svb;
102272343Sngie
103272343Sngie	/*
104272343Sngie	 * We cannot pass newfs parameters via the fstest interface,
105272343Sngie	 * so do things the oldfashioned manual way.
106272343Sngie	 */
107272343Sngie	snprintf(cmd, sizeof(cmd), "newfs -G -b %d -F -s 10000 "
108272343Sngie	    "ffs.img > /dev/null", MAXBSIZE * 2);
109272343Sngie	if (system(cmd))
110272343Sngie		atf_tc_fail("cannot create file system");
111272343Sngie
112272343Sngie	rump_init();
113272343Sngie	if (rump_pub_etfs_register("/devdisk", "ffs.img", RUMP_ETFS_BLK))
114272343Sngie		atf_tc_fail("cannot register rump fake device");
115272343Sngie
116272343Sngie	args.fspec = __UNCONST("/devdisk");
117272343Sngie
118272343Sngie	if (rump_sys_mkdir("/mp", 0777) == -1)
119272343Sngie		atf_tc_fail_errno("create mountpoint");
120272343Sngie
121272343Sngie	/* mount succeeded?  bad omen.  confirm we're in trouble.  */
122272343Sngie	if (rump_sys_mount(MOUNT_FFS, "/mp", 0, &args, sizeof(args)) != -1) {
123272343Sngie		rump_sys_statvfs1("/mp", &svb, ST_WAIT);
124272343Sngie		atf_tc_fail("not expecting to be alive");
125272343Sngie	}
126272343Sngie
127272343Sngie	/* otherwise we're do-ne */
128272343Sngie}
129272343Sngie
130272343SngieATF_TP_ADD_TCS(tp)
131272343Sngie{
132272343Sngie
133272343Sngie	ATF_TP_ADD_TC(tp, 48Kimage);
134272343Sngie	ATF_TP_ADD_TC(tp, fsbsizeovermaxphys);
135272343Sngie	ATF_TP_ADD_TC(tp, fsbsizeovermaxbsize);
136272343Sngie
137272343Sngie	return atf_no_error();
138272343Sngie}
139