cvs commit: src/sys/nfsclient nfs_bio.c nfs_node.c nfs_vnops.c nfsnode.h

Paul Saab ps at FreeBSD.org
Mon Dec 6 10:52:29 PST 2004


ps          2004-12-06 18:52:28 UTC

  FreeBSD src repository

  Modified files:
    sys/nfsclient        nfs_bio.c nfs_node.c nfs_vnops.c 
                         nfsnode.h 
  Log:
  Serialize NFS vinvalbuf operations by acquiring/upgrading to the
  vnode EXCLUSIVE lock. This prevents threads from adding pages to
  the vnode while an invalidation is in progress, closing potential
  races. In the bioread() path, callers acquire the SHARED vnode lock
  - so while an invalidate was in progress, it was possible to fault
  in new pages onto the vnode causing the invalidation to take a while
  or fail. We saw these races at Yahoo! with very large files+heavy
  concurrent access. Forcing an upgrade to EXCLUSIVE lock before doing
  the invalidation closes all these races.
  
  Submitted by:   Mohan Srinivasan mohans at yahoo-inc dot com
  
  Revision  Changes    Path
  1.141     +23 -26    src/sys/nfsclient/nfs_bio.c
  1.70      +1 -1      src/sys/nfsclient/nfs_node.c
  1.235     +0 -2      src/sys/nfsclient/nfs_vnops.c
  1.49      +0 -2      src/sys/nfsclient/nfsnode.h


More information about the cvs-all mailing list