When the insmntque() in the pfs_vncache_alloc() fails, vop_reclaim calls
pfs_vncache_free() that removes pvd from the list, while it is not yet put on the list. Prevent the invalid removal from the list by clearing pvd_next and pvd_prev for the newly allocated pvd, and only move pfs_vncache list head when the pvd was at the head. Suggested and approved by: des MFC after: 2 weeks
This commit is contained in:
parent
ddf9d24349
commit
78e4cea909
@ -149,6 +149,7 @@ pfs_vncache_alloc(struct mount *mp, struct vnode **vpp,
|
||||
|
||||
/* nope, get a new one */
|
||||
pvd = malloc(sizeof *pvd, M_PFSVNCACHE, M_WAITOK);
|
||||
pvd->pvd_next = pvd->pvd_prev = NULL;
|
||||
error = getnewvnode("pseudofs", mp, &pfs_vnodeops, vpp);
|
||||
if (error) {
|
||||
free(pvd, M_PFSVNCACHE);
|
||||
@ -245,7 +246,7 @@ pfs_vncache_free(struct vnode *vp)
|
||||
pvd->pvd_next->pvd_prev = pvd->pvd_prev;
|
||||
if (pvd->pvd_prev)
|
||||
pvd->pvd_prev->pvd_next = pvd->pvd_next;
|
||||
else
|
||||
else if (pfs_vncache == pvd)
|
||||
pfs_vncache = pvd->pvd_next;
|
||||
--pfs_vncache_entries;
|
||||
mtx_unlock(&pfs_vncache_mutex);
|
||||
|
Loading…
Reference in New Issue
Block a user