mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-12 14:29:28 +00:00
I ran into an nfs client panic a couple of times in a row over the
last few days. I tracked it down to the fact that nfs_reclaim() is setting vp->v_data to NULL _before_ calling vnode_destroy_object(). After silence from the mailing list I checked further and discovered that ufs_reclaim() is unique among FreeBSD filesystems for calling vnode_destroy_object() early, long before tossing v_data or much of anything else, for that matter. The rest, including NFS, appear to be identical, as if they were just clones of one original routine. The enclosed patch fixes all file systems in essentially the same way, by moving the call to vnode_destroy_object() to early in the routine (before the call to vfs_hash_remove(), if any). I have only tested NFS, but I've now run for over eighteen hours with the patch where I wouldn't get past four or five without it. Submitted by: Frank Mayhar Requested by: Mohan Srinivasan MFC After: 1 week
This commit is contained in:
parent
2971d7ab9b
commit
92e73f5711
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=154487
@ -97,6 +97,10 @@ cd9660_reclaim(ap)
|
||||
|
||||
if (prtactive && vrefcnt(vp) != 0)
|
||||
vprint("cd9660_reclaim: pushing active", vp);
|
||||
/*
|
||||
* Destroy the vm object and flush associated pages.
|
||||
*/
|
||||
vnode_destroy_vobject(vp);
|
||||
/*
|
||||
* Remove the inode from its hash chain.
|
||||
*/
|
||||
@ -109,7 +113,6 @@ cd9660_reclaim(ap)
|
||||
vrele(ip->i_mnt->im_devvp);
|
||||
FREE(vp->v_data, M_ISOFSNODE);
|
||||
vp->v_data = NULL;
|
||||
vnode_destroy_vobject(vp);
|
||||
return (0);
|
||||
}
|
||||
|
||||
|
@ -600,12 +600,16 @@ hpfs_reclaim(ap)
|
||||
|
||||
dprintf(("hpfs_reclaim(0x%x0): \n", hp->h_no));
|
||||
|
||||
/*
|
||||
* Destroy the vm object and flush associated pages.
|
||||
*/
|
||||
vnode_destroy_vobject(vp);
|
||||
|
||||
vfs_hash_remove(vp);
|
||||
|
||||
mtx_destroy(&hp->h_interlock);
|
||||
|
||||
vp->v_data = NULL;
|
||||
vnode_destroy_vobject(vp);
|
||||
|
||||
FREE(hp, M_HPFSNO);
|
||||
|
||||
|
@ -548,6 +548,10 @@ msdosfs_reclaim(ap)
|
||||
|
||||
if (prtactive && vrefcnt(vp) != 0)
|
||||
vprint("msdosfs_reclaim(): pushing active", vp);
|
||||
/*
|
||||
* Destroy the vm object and flush associated pages.
|
||||
*/
|
||||
vnode_destroy_vobject(vp);
|
||||
/*
|
||||
* Remove the denode from its hash chain.
|
||||
*/
|
||||
@ -560,7 +564,6 @@ msdosfs_reclaim(ap)
|
||||
#endif
|
||||
FREE(dep, M_MSDOSFSNODE);
|
||||
vp->v_data = NULL;
|
||||
vnode_destroy_vobject(vp);
|
||||
|
||||
return (0);
|
||||
}
|
||||
|
@ -248,6 +248,11 @@ ntfs_reclaim(ap)
|
||||
if (ntfs_prtactive && vrefcnt(vp) != 0)
|
||||
vprint("ntfs_reclaim: pushing active", vp);
|
||||
|
||||
/*
|
||||
* Destroy the vm object and flush associated pages.
|
||||
*/
|
||||
vnode_destroy_vobject(vp);
|
||||
|
||||
if ((error = ntfs_ntget(ip)) != 0)
|
||||
return (error);
|
||||
|
||||
@ -255,7 +260,6 @@ ntfs_reclaim(ap)
|
||||
ntfs_frele(fp);
|
||||
ntfs_ntput(ip);
|
||||
vp->v_data = NULL;
|
||||
vnode_destroy_vobject(vp);
|
||||
|
||||
return (0);
|
||||
}
|
||||
|
@ -255,6 +255,11 @@ nwfs_reclaim(ap)
|
||||
struct thread *td = ap->a_td;
|
||||
|
||||
NCPVNDEBUG("%s,%d\n", np->n_name, vrefcnt(vp));
|
||||
/*
|
||||
* Destroy the vm object and flush associated pages.
|
||||
*/
|
||||
vnode_destroy_vobject(vp);
|
||||
|
||||
if (np->n_flag & NREFPARENT) {
|
||||
np->n_flag &= ~NREFPARENT;
|
||||
if (nwfs_lookupnp(nmp, np->n_parent, td, &dnp) == 0) {
|
||||
@ -270,7 +275,6 @@ nwfs_reclaim(ap)
|
||||
nmp->n_root = NULL;
|
||||
}
|
||||
vp->v_data = NULL;
|
||||
vnode_destroy_vobject(vp);
|
||||
FREE(np, M_NWNODE);
|
||||
if (dvp) {
|
||||
vrele(dvp);
|
||||
|
@ -319,6 +319,10 @@ smbfs_reclaim(ap)
|
||||
KASSERT((np->n_flag & NOPEN) == 0, ("file not closed before reclaim"));
|
||||
|
||||
smbfs_hash_lock(smp, td);
|
||||
/*
|
||||
* Destroy the vm object and flush associated pages.
|
||||
*/
|
||||
vnode_destroy_vobject(vp);
|
||||
|
||||
dvp = (np->n_parent && (np->n_flag & NREFPARENT)) ?
|
||||
np->n_parent : NULL;
|
||||
@ -330,7 +334,6 @@ smbfs_reclaim(ap)
|
||||
smp->sm_root = NULL;
|
||||
}
|
||||
vp->v_data = NULL;
|
||||
vnode_destroy_vobject(vp);
|
||||
smbfs_hash_unlock(smp, td);
|
||||
if (np->n_name)
|
||||
smbfs_name_free(np->n_name);
|
||||
|
@ -965,6 +965,11 @@ udf_reclaim(struct vop_reclaim_args *a)
|
||||
vp = a->a_vp;
|
||||
unode = VTON(vp);
|
||||
|
||||
/*
|
||||
* Destroy the vm object and flush associated pages.
|
||||
*/
|
||||
vnode_destroy_vobject(vp);
|
||||
|
||||
if (unode != NULL) {
|
||||
vfs_hash_remove(vp);
|
||||
|
||||
@ -973,7 +978,6 @@ udf_reclaim(struct vop_reclaim_args *a)
|
||||
uma_zfree(udf_zone_node, unode);
|
||||
vp->v_data = NULL;
|
||||
}
|
||||
vnode_destroy_vobject(vp);
|
||||
|
||||
return (0);
|
||||
}
|
||||
|
@ -97,6 +97,10 @@ cd9660_reclaim(ap)
|
||||
|
||||
if (prtactive && vrefcnt(vp) != 0)
|
||||
vprint("cd9660_reclaim: pushing active", vp);
|
||||
/*
|
||||
* Destroy the vm object and flush associated pages.
|
||||
*/
|
||||
vnode_destroy_vobject(vp);
|
||||
/*
|
||||
* Remove the inode from its hash chain.
|
||||
*/
|
||||
@ -109,7 +113,6 @@ cd9660_reclaim(ap)
|
||||
vrele(ip->i_mnt->im_devvp);
|
||||
FREE(vp->v_data, M_ISOFSNODE);
|
||||
vp->v_data = NULL;
|
||||
vnode_destroy_vobject(vp);
|
||||
return (0);
|
||||
}
|
||||
|
||||
|
@ -211,6 +211,11 @@ nfs_reclaim(struct vop_reclaim_args *ap)
|
||||
if (prtactive && vrefcnt(vp) != 0)
|
||||
vprint("nfs_reclaim: pushing active", vp);
|
||||
|
||||
/*
|
||||
* Destroy the vm object and flush associated pages.
|
||||
*/
|
||||
vnode_destroy_vobject(vp);
|
||||
|
||||
vfs_hash_remove(vp);
|
||||
|
||||
/*
|
||||
@ -232,6 +237,5 @@ nfs_reclaim(struct vop_reclaim_args *ap)
|
||||
|
||||
uma_zfree(nfsnode_zone, vp->v_data);
|
||||
vp->v_data = NULL;
|
||||
vnode_destroy_vobject(vp);
|
||||
return (0);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user