Replace the workaround for a deadlock bug in Coda with a different

workaround that does not rely on vfs_start().
This commit is contained in:
David Schultz 2005-02-20 23:01:57 +00:00
parent 325ce5d8fb
commit 0e2b18143f
4 changed files with 8 additions and 32 deletions

@ -290,8 +290,8 @@ coda_root(vfsp, vpp, td)
* on to Venus if the root vnode is the dummy we installed in
* coda_omount() with all c_fid members zeroed.
*
* XXX In addition, if we are called between coda_omount() and
* coda_start(), we assume that the request is from vfs_omount()
* XXX In addition, we assume that the first call to coda_root()
* is from vfs_omount()
* (before the call to checkdirs()) and return the dummy root
* node to avoid a deadlock. This bug is fixed in the Coda CVS
* repository but not in any released versions as of 6 Mar 2003.
@ -300,6 +300,8 @@ coda_root(vfsp, vpp, td)
sizeof(CodaFid)) != 0 || mi->mi_started == 0)
{ /* Found valid root. */
*vpp = mi->mi_rootvp;
mi->mi_started = 1;
/* On Mach, this is vref. On NetBSD, VOP_LOCK */
#if 1
vref(*vpp);
@ -365,18 +367,6 @@ coda_root(vfsp, vpp, td)
return(error);
}
int
coda_start(mp, flags, td)
struct mount *mp;
int flags;
struct thread *td;
{
/* XXX See coda_root(). */
vftomi(mp)->mi_started = 1;
return (0);
}
/*
* Get filesystem statistics.
*/
@ -531,7 +521,6 @@ struct mount *devtomp(dev)
struct vfsops coda_vfsops = {
.vfs_mount = coda_mount,
.vfs_root = coda_root,
.vfs_start = coda_start,
.vfs_statfs = coda_nb_statfs,
.vfs_sync = coda_sync,
.vfs_unmount = coda_unmount,

@ -51,7 +51,6 @@ int coda_fhtovp(struct mount *, struct fid *, struct mbuf *, struct vnode **,
int *, struct ucred **);
vfs_mount_t coda_mount;
vfs_start_t coda_start;
vfs_unmount_t coda_unmount;
vfs_root_t coda_root;
vfs_quotactl_t coda_quotactl;

@ -290,8 +290,8 @@ coda_root(vfsp, vpp, td)
* on to Venus if the root vnode is the dummy we installed in
* coda_omount() with all c_fid members zeroed.
*
* XXX In addition, if we are called between coda_omount() and
* coda_start(), we assume that the request is from vfs_omount()
* XXX In addition, we assume that the first call to coda_root()
* is from vfs_omount()
* (before the call to checkdirs()) and return the dummy root
* node to avoid a deadlock. This bug is fixed in the Coda CVS
* repository but not in any released versions as of 6 Mar 2003.
@ -300,6 +300,8 @@ coda_root(vfsp, vpp, td)
sizeof(CodaFid)) != 0 || mi->mi_started == 0)
{ /* Found valid root. */
*vpp = mi->mi_rootvp;
mi->mi_started = 1;
/* On Mach, this is vref. On NetBSD, VOP_LOCK */
#if 1
vref(*vpp);
@ -365,18 +367,6 @@ coda_root(vfsp, vpp, td)
return(error);
}
int
coda_start(mp, flags, td)
struct mount *mp;
int flags;
struct thread *td;
{
/* XXX See coda_root(). */
vftomi(mp)->mi_started = 1;
return (0);
}
/*
* Get filesystem statistics.
*/
@ -531,7 +521,6 @@ struct mount *devtomp(dev)
struct vfsops coda_vfsops = {
.vfs_mount = coda_mount,
.vfs_root = coda_root,
.vfs_start = coda_start,
.vfs_statfs = coda_nb_statfs,
.vfs_sync = coda_sync,
.vfs_unmount = coda_unmount,

@ -51,7 +51,6 @@ int coda_fhtovp(struct mount *, struct fid *, struct mbuf *, struct vnode **,
int *, struct ucred **);
vfs_mount_t coda_mount;
vfs_start_t coda_start;
vfs_unmount_t coda_unmount;
vfs_root_t coda_root;
vfs_quotactl_t coda_quotactl;