Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/coda Remove cnodes from coda_reclaim(), not from coda_in...



details:   https://anonhg.NetBSD.org/src/rev/be06d1a48789
branches:  trunk
changeset: 334882:be06d1a48789
user:      hannken <hannken%NetBSD.org@localhost>
date:      Sat Dec 13 15:59:03 2014 +0000

description:
Remove cnodes from coda_reclaim(), not from coda_inactive().

diffstat:

 sys/coda/coda_vnops.c |  28 ++++++++++++++--------------
 1 files changed, 14 insertions(+), 14 deletions(-)

diffs (56 lines):

diff -r d1955271323a -r be06d1a48789 sys/coda/coda_vnops.c
--- a/sys/coda/coda_vnops.c     Sat Dec 13 15:58:39 2014 +0000
+++ b/sys/coda/coda_vnops.c     Sat Dec 13 15:59:03 2014 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: coda_vnops.c,v 1.99 2014/12/13 15:57:46 hannken Exp $  */
+/*     $NetBSD: coda_vnops.c,v 1.100 2014/12/13 15:59:03 hannken Exp $ */
 
 /*
  *
@@ -46,7 +46,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: coda_vnops.c,v 1.99 2014/12/13 15:57:46 hannken Exp $");
+__KERNEL_RCSID(0, "$NetBSD: coda_vnops.c,v 1.100 2014/12/13 15:59:03 hannken Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -844,18 +844,6 @@
     CODADEBUG(CODA_INACTIVE, myprintf(("in inactive, %s, vfsp %p\n",
                                  coda_f2s(&cp->c_fid), vp->v_mount));)
 
-    /* If an array has been allocated to hold the symlink, deallocate it */
-    if ((coda_symlink_cache) && (VALID_SYMLINK(cp))) {
-       if (cp->c_symlink == NULL)
-           panic("%s: null symlink pointer in cnode", __func__);
-
-       CODA_FREE(cp->c_symlink, cp->c_symlen);
-       cp->c_flags &= ~C_SYMLINK;
-       cp->c_symlen = 0;
-    }
-
-    /* Remove it from the table so it can't be found. */
-    coda_unsave(cp);
     if (vp->v_mount->mnt_data == NULL) {
        myprintf(("Help! vfsp->vfs_data was NULL, but vnode %p wasn't dying\n", vp));
        panic("badness in coda_inactive");
@@ -1676,6 +1664,18 @@
        }
 #endif
     }
+    /* If an array has been allocated to hold the symlink, deallocate it */
+    if ((coda_symlink_cache) && (VALID_SYMLINK(cp))) {
+       if (cp->c_symlink == NULL)
+           panic("%s: null symlink pointer in cnode", __func__);
+
+       CODA_FREE(cp->c_symlink, cp->c_symlen);
+       cp->c_flags &= ~C_SYMLINK;
+       cp->c_symlen = 0;
+    }
+
+    /* Remove it from the table so it can't be found. */
+    coda_unsave(cp);
     coda_free(VTOC(vp));
     SET_VTOC(vp) = NULL;
     return (0);



Home | Main Index | Thread Index | Old Index