2005-01-05 23:35:00 +00:00
|
|
|
/*-
|
1998-09-02 19:09:53 +00:00
|
|
|
* Coda: an Experimental Distributed File System
|
|
|
|
* Release 3.1
|
2008-02-10 11:18:12 +00:00
|
|
|
*
|
1998-09-02 19:09:53 +00:00
|
|
|
* Copyright (c) 1987-1998 Carnegie Mellon University
|
|
|
|
* All Rights Reserved
|
2008-02-10 11:18:12 +00:00
|
|
|
*
|
1998-09-02 19:09:53 +00:00
|
|
|
* Permission to use, copy, modify and distribute this software and its
|
|
|
|
* documentation is hereby granted, provided that both the copyright
|
|
|
|
* notice and this permission notice appear in all copies of the
|
|
|
|
* software, derivative works or modified versions, and any portions
|
|
|
|
* thereof, and that both notices appear in supporting documentation, and
|
|
|
|
* that credit is given to Carnegie Mellon University in all documents
|
|
|
|
* and publicity pertaining to direct or indirect use of this code or its
|
|
|
|
* derivatives.
|
2008-02-10 11:18:12 +00:00
|
|
|
*
|
1998-09-02 19:09:53 +00:00
|
|
|
* CODA IS AN EXPERIMENTAL SOFTWARE SYSTEM AND IS KNOWN TO HAVE BUGS,
|
|
|
|
* SOME OF WHICH MAY HAVE SERIOUS CONSEQUENCES. CARNEGIE MELLON ALLOWS
|
|
|
|
* FREE USE OF THIS SOFTWARE IN ITS "AS IS" CONDITION. CARNEGIE MELLON
|
|
|
|
* DISCLAIMS ANY LIABILITY OF ANY KIND FOR ANY DAMAGES WHATSOEVER
|
|
|
|
* RESULTING DIRECTLY OR INDIRECTLY FROM THE USE OF THIS SOFTWARE OR OF
|
|
|
|
* ANY DERIVATIVE WORK.
|
2008-02-10 11:18:12 +00:00
|
|
|
*
|
1998-09-02 19:09:53 +00:00
|
|
|
* Carnegie Mellon encourages users of this software to return any
|
|
|
|
* improvements or extensions that they make, and to grant Carnegie
|
|
|
|
* Mellon the rights to redistribute these changes without encumbrance.
|
2008-02-10 11:18:12 +00:00
|
|
|
*
|
1998-09-13 13:57:59 +00:00
|
|
|
* @(#) src/sys/coda/coda_fbsd.cr,v 1.1.1.1 1998/08/29 21:14:52 rvb Exp $
|
1998-09-02 19:09:53 +00:00
|
|
|
*/
|
1998-08-29 21:14:52 +00:00
|
|
|
|
2003-06-10 21:29:12 +00:00
|
|
|
#include <sys/cdefs.h>
|
|
|
|
__FBSDID("$FreeBSD$");
|
|
|
|
|
1998-08-29 21:14:52 +00:00
|
|
|
#include <sys/param.h>
|
|
|
|
#include <sys/systm.h>
|
2001-05-01 08:13:21 +00:00
|
|
|
#include <sys/conf.h>
|
|
|
|
#include <sys/fcntl.h>
|
1998-08-29 21:14:52 +00:00
|
|
|
#include <sys/kernel.h>
|
2001-05-01 08:13:21 +00:00
|
|
|
#include <sys/lock.h>
|
1998-09-02 19:09:53 +00:00
|
|
|
#include <sys/malloc.h>
|
2004-05-30 20:27:19 +00:00
|
|
|
#include <sys/module.h>
|
1998-08-29 21:14:52 +00:00
|
|
|
#include <sys/ucred.h>
|
1998-09-02 19:09:53 +00:00
|
|
|
#include <sys/vnode.h>
|
|
|
|
|
1998-08-29 21:14:52 +00:00
|
|
|
#include <vm/vm.h>
|
|
|
|
#include <vm/vnode_pager.h>
|
|
|
|
|
2007-07-12 21:04:58 +00:00
|
|
|
#include <fs/coda/coda.h>
|
|
|
|
#include <fs/coda/cnode.h>
|
|
|
|
#include <fs/coda/coda_vnops.h>
|
|
|
|
#include <fs/coda/coda_psdev.h>
|
1998-08-29 21:14:52 +00:00
|
|
|
|
1999-05-30 16:53:49 +00:00
|
|
|
static struct cdevsw codadevsw = {
|
2004-02-21 21:10:55 +00:00
|
|
|
.d_version = D_VERSION,
|
|
|
|
.d_flags = D_NEEDGIANT,
|
Various further non-functional cleanups to coda:
- Rename print_vattr to coda_print_vattr and make static, rename
print_cred to coda_print_cred.
- Remove unused coda_vop_nop.
- Add XXX comment because coda_readdir forwards to the cache vnode's
readdir rather than venus_readdir, and annotate venus_readdir as
unused.
- Rename vc_nb_* to vc_*.
- Use d_open_t, d_close_t, d_read_t, d_write_t, d_ioctl_t and d_poll_t
for prototyping vc_* as that is the intent, don't use our own
definitions.
- Rename coda_nb_statfs to coda_statfs, rename NB_SFS_SIZ to
CODA_SFS_SIZ.
- Replace one more OBE reference to NetBSD with a reference to FreeBSD.
- Tidy up a little vertical whitespace here and there.
- Annotate coda_nc_zapvnode as unused.
- Remove unused vcodattach.
- Annotate VM_INTR as unused.
- Annotate that coda_fhtovp is unused and doesn't match the FreeBSD
prototype, so isn't hooked up to vfs_fhtovp. If we want NFS export of
Coda to work someday, this needs to be fixed.
- Remove unused getNewVnode.
- Remove unused coda_vget, coda_init, coda_quotactl prototypes.
MFC after: 1 month
2008-02-09 12:49:18 +00:00
|
|
|
.d_open = vc_open,
|
|
|
|
.d_close = vc_close,
|
|
|
|
.d_read = vc_read,
|
|
|
|
.d_write = vc_write,
|
|
|
|
.d_ioctl = vc_ioctl,
|
|
|
|
.d_poll = vc_poll,
|
|
|
|
.d_name = "coda",
|
1998-09-02 19:09:53 +00:00
|
|
|
};
|
1998-08-29 21:14:52 +00:00
|
|
|
|
2004-09-01 01:19:52 +00:00
|
|
|
static eventhandler_tag clonetag;
|
|
|
|
|
|
|
|
static LIST_HEAD(, coda_mntinfo) coda_mnttbl;
|
|
|
|
|
2008-02-10 11:18:12 +00:00
|
|
|
/*
|
|
|
|
* For DEVFS, using bpf & tun drivers as examples.
|
|
|
|
*
|
|
|
|
* XXX: Why use a cloned interface, aren't we really just interested in
|
|
|
|
* having a single /dev/cfs0? It's not clear the coda module knows what to
|
|
|
|
* do with more than one.
|
|
|
|
*/
|
2005-08-08 19:55:32 +00:00
|
|
|
static void coda_fbsd_clone(void *arg, struct ucred *cred, char *name,
|
|
|
|
int namelen, struct cdev **dev);
|
2004-09-01 01:19:52 +00:00
|
|
|
|
1998-11-03 08:55:06 +00:00
|
|
|
static int
|
1999-01-28 00:57:57 +00:00
|
|
|
codadev_modevent(module_t mod, int type, void *data)
|
1998-08-29 21:14:52 +00:00
|
|
|
{
|
2008-02-10 11:18:12 +00:00
|
|
|
struct coda_mntinfo *mnt;
|
1998-08-29 21:14:52 +00:00
|
|
|
|
1998-11-03 08:55:06 +00:00
|
|
|
switch (type) {
|
|
|
|
case MOD_LOAD:
|
2004-09-01 01:19:52 +00:00
|
|
|
LIST_INIT(&coda_mnttbl);
|
|
|
|
clonetag = EVENTHANDLER_REGISTER(dev_clone, coda_fbsd_clone,
|
|
|
|
0, 1000);
|
1998-11-03 08:55:06 +00:00
|
|
|
break;
|
2008-02-10 11:18:12 +00:00
|
|
|
|
1998-11-03 08:55:06 +00:00
|
|
|
case MOD_UNLOAD:
|
2008-02-10 11:18:12 +00:00
|
|
|
/*
|
|
|
|
* XXXRW: At the very least, a busy check should occur here
|
|
|
|
* to prevent untimely unload. Much more serious collection
|
|
|
|
* of allocated memory needs to take place; right now we leak
|
|
|
|
* like a sieve.
|
|
|
|
*/
|
2004-09-01 01:19:52 +00:00
|
|
|
EVENTHANDLER_DEREGISTER(dev_clone, clonetag);
|
|
|
|
while ((mnt = LIST_FIRST(&coda_mnttbl)) != NULL) {
|
|
|
|
LIST_REMOVE(mnt, mi_list);
|
|
|
|
destroy_dev(mnt->dev);
|
|
|
|
free(mnt, M_CODA);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
1998-11-03 08:55:06 +00:00
|
|
|
default:
|
2004-07-15 08:26:07 +00:00
|
|
|
return (EOPNOTSUPP);
|
1998-11-03 08:55:06 +00:00
|
|
|
}
|
2008-02-10 11:18:12 +00:00
|
|
|
return (0);
|
1998-08-29 21:14:52 +00:00
|
|
|
}
|
2008-02-10 11:18:12 +00:00
|
|
|
|
1998-11-03 08:55:06 +00:00
|
|
|
static moduledata_t codadev_mod = {
|
|
|
|
"codadev",
|
|
|
|
codadev_modevent,
|
|
|
|
NULL
|
|
|
|
};
|
2004-09-01 01:19:52 +00:00
|
|
|
DECLARE_MODULE(codadev, codadev_mod, SI_SUB_DRIVERS, SI_ORDER_MIDDLE);
|
1998-11-03 08:55:06 +00:00
|
|
|
|
2008-02-10 11:18:12 +00:00
|
|
|
static void
|
|
|
|
coda_fbsd_clone(void *arg, struct ucred *cred, char *name, int namelen,
|
|
|
|
struct cdev **dev)
|
2001-06-05 19:45:16 +00:00
|
|
|
{
|
2008-02-10 11:18:12 +00:00
|
|
|
struct coda_mntinfo *mnt;
|
|
|
|
int u;
|
|
|
|
|
|
|
|
if (*dev != NULL)
|
|
|
|
return;
|
|
|
|
if (dev_stdclone(name, NULL, "cfs", &u) != 1)
|
|
|
|
return;
|
|
|
|
*dev = make_dev(&codadevsw, unit2minor(u), UID_ROOT, GID_WHEEL, 0600,
|
|
|
|
"cfs%d", u);
|
|
|
|
dev_ref(*dev);
|
|
|
|
mnt = malloc(sizeof(struct coda_mntinfo), M_CODA, M_WAITOK|M_ZERO);
|
|
|
|
LIST_INSERT_HEAD(&coda_mnttbl, mnt, mi_list);
|
|
|
|
mnt->dev = *dev;
|
2001-06-05 19:45:16 +00:00
|
|
|
}
|
|
|
|
|
2004-09-01 01:19:52 +00:00
|
|
|
struct coda_mntinfo *
|
|
|
|
dev2coda_mntinfo(struct cdev *dev)
|
2001-06-05 19:45:16 +00:00
|
|
|
{
|
2008-02-10 11:18:12 +00:00
|
|
|
struct coda_mntinfo *mnt;
|
2001-06-05 19:45:16 +00:00
|
|
|
|
2004-09-01 01:19:52 +00:00
|
|
|
LIST_FOREACH(mnt, &coda_mnttbl, mi_list) {
|
|
|
|
if (mnt->dev == dev)
|
2008-02-10 11:18:12 +00:00
|
|
|
return (mnt);
|
2004-09-01 01:19:52 +00:00
|
|
|
}
|
2008-02-10 11:18:12 +00:00
|
|
|
return (NULL);
|
2001-06-05 19:45:16 +00:00
|
|
|
}
|