/* $NetBSD: lkminit_vfs.c,v 1.12 2008/04/28 20:24:07 martin Exp $ */ /*- * Copyright (c) 1996 The NetBSD Foundation, Inc. * All rights reserved. * * This code is derived from software contributed to The NetBSD Foundation * by Michael Graff <explorer@flame.org>. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. */ #include <sys/cdefs.h> __KERNEL_RCSID(0, "$NetBSD: lkminit_vfs.c,v 1.12 2008/04/28 20:24:07 martin Exp $"); #include <sys/param.h> #include <sys/sysctl.h> #include <sys/ioctl.h> #include <sys/systm.h> #include <sys/conf.h> #include <sys/mount.h> #include <sys/exec.h> #include <sys/lkm.h> #include <sys/file.h> #include <sys/errno.h> #include <coda/coda.h> #include <coda/coda_vfsops.h> #ifdef CODA_COMPAT_5 int coda5_lkmentry(struct lkm_table *, int, int); #else int coda_lkmentry(struct lkm_table *, int, int); #endif static int coda_dispatch_vfs(struct lkm_table *, int, int); static int coda_dispatch_dev(struct lkm_table *, int, int); /* * The VFS part of module. */ static int coda_dispatch_vfs(struct lkm_table *lkmtp, int cmd, int ver) { extern struct vfsops coda_vfsops; /* * declare the filesystem */ MOD_VFS("coda", -1, &coda_vfsops); lkmtp->private.lkm_any = (void *) &_module; /* XXX */ DISPATCH(lkmtp, cmd, ver, lkm_nofunc, lkm_nofunc, lkm_nofunc); } /* * The device part. */ static int coda_dispatch_dev(struct lkm_table *lkmtp, int cmd, int ver) { /* * declare up/down call device */ extern const struct cdevsw vcoda_cdevsw; MOD_DEV("vcoda", "vcoda", NULL, -1, &vcoda_cdevsw, -1); lkmtp->private.lkm_any = (void *) &_module; /* XXX */ DISPATCH(lkmtp, cmd, ver, lkm_nofunc, lkm_nofunc, lkm_nofunc); } /* * entry point */ int #ifdef CODA_COMPAT_5 coda5_lkmentry(struct lkm_table *lkmtp, int cmd, int ver) #else coda_lkmentry(struct lkm_table *lkmtp, int cmd, int ver) #endif { int error = 0; static struct sysctllog *_coda_log; switch (cmd) { case LKM_E_LOAD: error = coda_dispatch_dev(lkmtp, cmd, ver); if (error) break; error = coda_dispatch_vfs(lkmtp, cmd, ver); if (!error) sysctl_vfs_coda_setup(&_coda_log); break; case LKM_E_UNLOAD: sysctl_teardown(&_coda_log); error = coda_dispatch_vfs(lkmtp, cmd, ver); if (error) break; error = coda_dispatch_dev(lkmtp, cmd, ver); break; case LKM_E_STAT: error = lkmdispatch(lkmtp, cmd); break; } return error; }