Source-Changes-HG archive

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

[src/trunk]: src/sys/fs/udf Move the removal of unlinked nodes from udf_inact...



details:   https://anonhg.NetBSD.org/src/rev/47a3b1ed0efe
branches:  trunk
changeset: 337195:47a3b1ed0efe
user:      hannken <hannken%NetBSD.org@localhost>
date:      Mon Apr 06 08:38:25 2015 +0000

description:
Move the removal of unlinked nodes from udf_inactive() to udf_reclaim().

diffstat:

 sys/fs/udf/udf_vnops.c |  29 +++++++++++++++++++++--------
 1 files changed, 21 insertions(+), 8 deletions(-)

diffs (72 lines):

diff -r 4017286391b0 -r 47a3b1ed0efe sys/fs/udf/udf_vnops.c
--- a/sys/fs/udf/udf_vnops.c    Mon Apr 06 07:38:17 2015 +0000
+++ b/sys/fs/udf/udf_vnops.c    Mon Apr 06 08:38:25 2015 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: udf_vnops.c,v 1.98 2015/04/04 12:34:45 riastradh Exp $ */
+/* $NetBSD: udf_vnops.c,v 1.99 2015/04/06 08:38:25 hannken Exp $ */
 
 /*
  * Copyright (c) 2006, 2008 Reinoud Zandijk
@@ -32,7 +32,7 @@
 
 #include <sys/cdefs.h>
 #ifndef lint
-__KERNEL_RCSID(0, "$NetBSD: udf_vnops.c,v 1.98 2015/04/04 12:34:45 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: udf_vnops.c,v 1.99 2015/04/06 08:38:25 hannken Exp $");
 #endif /* not lint */
 
 
@@ -97,9 +97,7 @@
        }
 
        /*
-        * Optionally flush metadata to disc. If the file has not been
-        * referenced anymore in a directory we ought to free up the resources
-        * on disc if applicable.
+        * Optionally flush metadata to disc.
         */
        if (udf_node->fe) {
                refcnt = udf_rw16(udf_node->fe->link_cnt);
@@ -116,10 +114,7 @@
 
        *ap->a_recycle = false;
        if ((refcnt == 0) && ((vp->v_vflag & VV_SYSTEM) == 0)) {
-               /* remove this file's allocation */
-               DPRINTF(NODE, ("udf_inactive deleting unlinked file\n"));
                *ap->a_recycle = true;
-               udf_delete_node(udf_node);
                VOP_UNLOCK(vp);
                return 0;
        }
@@ -144,6 +139,7 @@
        } */ *ap = v;
        struct vnode *vp = ap->a_vp;
        struct udf_node *udf_node = VTOI(vp);
+       int refcnt;
 
        DPRINTF(NODE, ("udf_reclaim called for node %p\n", udf_node));
        if (prtactive && vp->v_usecount > 1)
@@ -154,6 +150,23 @@
                return 0;
        }
 
+       /*
+        * If the file has not been referenced anymore in a directory
+        * we ought to free up the resources on disc if applicable.
+        */
+       if (udf_node->fe) {
+               refcnt = udf_rw16(udf_node->fe->link_cnt);
+       } else {
+               assert(udf_node->efe);
+               refcnt = udf_rw16(udf_node->efe->link_cnt);
+       }
+
+       if ((refcnt == 0) && ((vp->v_vflag & VV_SYSTEM) == 0)) {
+               /* remove this file's allocation */
+               DPRINTF(NODE, ("udf_inactive deleting unlinked file\n"));
+               udf_delete_node(udf_node);
+       }
+
        /* update note for closure */
        udf_update(vp, NULL, NULL, NULL, UPDATE_CLOSE);
 



Home | Main Index | Thread Index | Old Index