
to store disk quota usage and limits, integrated with ffs metadata. Usage is checked by fsck_ffs (no more quotacheck) and is covered by the WAPBL journal. Enabled with kernel option QUOTA2 (added where QUOTA was enabled in kernel config files), turned on with tunefs(8) on a per-filesystem basis. mount_mfs(8) can also turn quotas on. See http://mail-index.netbsd.org/tech-kern/2011/02/19/msg010025.html for details.
116 lines
2.0 KiB
C
116 lines
2.0 KiB
C
/* $NetBSD: h_quota2_server.c,v 1.2 2011/03/06 17:08:40 bouyer Exp $ */
|
|
|
|
/*
|
|
* rump server for advanced quota tests
|
|
*/
|
|
|
|
#include "../common/h_fsmacros.h"
|
|
|
|
#include <err.h>
|
|
#include <semaphore.h>
|
|
#include <sys/types.h>
|
|
#include <sys/mount.h>
|
|
|
|
#include <stdlib.h>
|
|
#include <unistd.h>
|
|
|
|
#include <ufs/ufs/ufsmount.h>
|
|
|
|
#include <rump/rump.h>
|
|
#include <rump/rump_syscalls.h>
|
|
|
|
#include "../../h_macros.h"
|
|
|
|
int background = 0;
|
|
|
|
static void
|
|
usage(void)
|
|
{
|
|
fprintf(stderr, "usage: %s [-b] [-l] diskimage bindurl\n",
|
|
getprogname());
|
|
exit(1);
|
|
}
|
|
|
|
static void
|
|
die(const char *reason, int error)
|
|
{
|
|
|
|
warnx("%s: %s", reason, strerror(error));
|
|
if (background)
|
|
rump_daemonize_done(error);
|
|
exit(1);
|
|
}
|
|
|
|
static sem_t sigsem;
|
|
static void
|
|
sigreboot(int sig)
|
|
{
|
|
|
|
sem_post(&sigsem);
|
|
}
|
|
|
|
int
|
|
main(int argc, char **argv)
|
|
{
|
|
int error;
|
|
struct ufs_args uargs;
|
|
const char *filename;
|
|
const char *serverurl;
|
|
int log = 0;
|
|
int ch;
|
|
|
|
while ((ch = getopt(argc, argv, "bl")) != -1) {
|
|
switch(ch) {
|
|
case 'b':
|
|
background = 1;
|
|
break;
|
|
case 'l':
|
|
log = 1;
|
|
break;
|
|
default:
|
|
usage();
|
|
}
|
|
}
|
|
argc -= optind;
|
|
argv += optind;
|
|
|
|
if (argc != 2)
|
|
usage();
|
|
|
|
filename = argv[0];
|
|
serverurl = argv[1];
|
|
|
|
if (background) {
|
|
error = rump_daemonize_begin();
|
|
if (error)
|
|
errx(1, "rump daemonize: %s", strerror(error));
|
|
}
|
|
|
|
error = rump_init();
|
|
if (error)
|
|
die("rump init failed", error);
|
|
|
|
if (rump_sys_mkdir(FSTEST_MNTNAME, 0777) == -1)
|
|
atf_tc_fail_errno("mount point create");
|
|
rump_pub_etfs_register("/diskdev", filename, RUMP_ETFS_BLK);
|
|
uargs.fspec = __UNCONST("/diskdev");
|
|
if (rump_sys_mount(MOUNT_FFS, FSTEST_MNTNAME, (log) ? MNT_LOG : 0,
|
|
&uargs, sizeof(uargs)) == -1)
|
|
die("mount ffs", errno);
|
|
|
|
error = rump_init_server(serverurl);
|
|
if (error)
|
|
die("rump server init failed", error);
|
|
if (background)
|
|
rump_daemonize_done(RUMP_DAEMONIZE_SUCCESS);
|
|
|
|
sem_init(&sigsem, 0, 0);
|
|
signal(SIGTERM, sigreboot);
|
|
signal(SIGINT, sigreboot);
|
|
sem_wait(&sigsem);
|
|
|
|
rump_sys_reboot(0, NULL);
|
|
/*NOTREACHED*/
|
|
return 0;
|
|
}
|