Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 17 Jun 2005 01:05:13 +0000 (UTC)
From:      Jeff Roberson <jeff@FreeBSD.org>
To:        src-committers@FreeBSD.org, cvs-src@FreeBSD.org, cvs-all@FreeBSD.org
Subject:   cvs commit: src/sys/kern vfs_cache.c
Message-ID:  <200506170105.j5H15EhR075282@repoman.freebsd.org>

next in thread | raw e-mail | index | archive | help
jeff        2005-06-17 01:05:13 UTC

  FreeBSD src repository

  Modified files:
    sys/kern             vfs_cache.c 
  Log:
   - Fix a leaked reference to a vnode via v_dd.  We rely on cache_purge() and
     cache_zap() to clear the v_dd pointers when a directory vnode is forcibly
     discarded.  For this to work, all vnodes with v_dd pointers to a directory
     must also have name cache entries linked via v_cache_dst to that dvp
     otherwise we could not find them at cache_purge() time.  The following
     code snipit could break this guarantee by unlinking a directory before
     fetching it's dotdot.  The dotdot lookup would initialize the v_dd field
     of the unlinked directory which could never be cleared.  To fix this
     we don't initialize v_dd for orphaned vnodes.
          printf("rmdir: %d\n", rmdir("../foo")); /* foo is cwd */
          printf("chdir: %d\n", chdir(".."));
          printf("%s\n", getwd(NULL));
  
  Sponsored by:   Isilon Systems, Inc.
  Discovered by:  kkenn
  Approved by:    re (blanket vfs)
  
  Revision  Changes    Path
  1.103     +11 -1     src/sys/kern/vfs_cache.c



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200506170105.j5H15EhR075282>