Author: csjp
Date: Fri Mar 20 00:55:38 2009
New Revision: 190120
URL: http://svn.freebsd.org/changeset/base/190120

Log:
  MFC r184660
  
  - Dont hold Giant around vn_fullpath and vn_fullpath_global

Modified:
  stable/7/sys/   (props changed)
  stable/7/sys/contrib/pf/   (props changed)
  stable/7/sys/dev/ath/ath_hal/   (props changed)
  stable/7/sys/dev/cxgb/   (props changed)
  stable/7/sys/security/audit/audit_bsm_klib.c

Modified: stable/7/sys/security/audit/audit_bsm_klib.c
==============================================================================
--- stable/7/sys/security/audit/audit_bsm_klib.c        Fri Mar 20 00:38:14 
2009        (r190119)
+++ stable/7/sys/security/audit/audit_bsm_klib.c        Fri Mar 20 00:55:38 
2009        (r190120)
@@ -492,7 +492,7 @@ audit_canon_path(struct thread *td, char
        char *rbuf, *fbuf, *copy;
        struct filedesc *fdp;
        struct sbuf sbf;
-       int error, cwir, locked;
+       int error, cwir;
 
        WITNESS_WARN(WARN_GIANTOK | WARN_SLEEPOK, NULL, "%s: at %s:%d",
            __func__,  __FILE__, __LINE__);
@@ -539,17 +539,8 @@ audit_canon_path(struct thread *td, char
         * in the future.
         */
        if (rvnp != NULL) {
-               /*
-                * Although unlikely, it is possible for filesystems to define
-                * their own VOP_LOCK, so strictly speaking, we need to
-                * conditionally pickup Giant around calls to vn_lock(9)
-                */
-               locked = VFS_LOCK_GIANT(rvnp->v_mount);
-               vn_lock(rvnp, LK_EXCLUSIVE | LK_RETRY, td);
-               vdrop(rvnp);
                error = vn_fullpath_global(td, rvnp, &rbuf, &fbuf);
-               VOP_UNLOCK(rvnp, 0, td);
-               VFS_UNLOCK_GIANT(locked);
+               vdrop(rvnp);
                if (error) {
                        cpath[0] = '\0';
                        if (cvnp != NULL)
@@ -560,12 +551,8 @@ audit_canon_path(struct thread *td, char
                free(fbuf, M_TEMP);
        }
        if (cvnp != NULL) {
-               locked = VFS_LOCK_GIANT(cvnp->v_mount);
-               vn_lock(cvnp, LK_EXCLUSIVE | LK_RETRY, td);
-               vdrop(cvnp);
                error = vn_fullpath(td, cvnp, &rbuf, &fbuf);
-               VOP_UNLOCK(cvnp, 0, td);
-               VFS_UNLOCK_GIANT(locked);
+               vdrop(cvnp);
                if (error) {
                        cpath[0] = '\0';
                        return;
_______________________________________________
svn-src-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to