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