git: network - Tokenize NFS, fix MP races

Matthew Dillon dillon at crater.dragonflybsd.org
Fri Sep 10 12:16:47 PDT 2010


commit c6b43e93a6cf0a70bde32cd141057a0df9860e13
Author: Matthew Dillon <dillon at apollo.backplane.com>
Date:   Fri Sep 10 12:09:34 2010 -0700

    network - Tokenize NFS, fix MP races
    
    * Now that the rest of the network stack is running MPSAFE, poor NFS is
      hitting races and other issues because it was depending on the MP lock.
    
    * Recombobulate NFS with tokens, protecting all border crossings:
    
      A global nfs_token is used for the nfs mount list, nfsd list, and
      server socket list.
    
      A per-socket token (nfssvc_sock->ns_token) governs each served mount.
    
      A per-mount token (nfsmount->nm_token) governs each client mount.
    
    * Callouts and TCP upcalls are protected.  The per-socket TCP upcall
      is protected by the nfssvc_sock token.
    
    * The NFS iod thread pairs and nfsd threads now run MPSAFE.
    
    * NFSv3 is now holy-shit fast and can trivially max-out a GigE link
      without TSO when the server is not otherwise limited by server-side
      disks.

Summary of changes:
 sys/vfs/nfs/nfs.h          |    7 ++-
 sys/vfs/nfs/nfs_bio.c      |   14 ++--
 sys/vfs/nfs/nfs_iod.c      |   19 +----
 sys/vfs/nfs/nfs_node.c     |   11 +++-
 sys/vfs/nfs/nfs_socket.c   |   32 +++++++-
 sys/vfs/nfs/nfs_subs.c     |    8 ++-
 sys/vfs/nfs/nfs_syscalls.c |   91 ++++++++++++++++++-----
 sys/vfs/nfs/nfs_vfsops.c   |   41 +++++++++-
 sys/vfs/nfs/nfs_vnops.c    |  174 ++++++++++++++++++++++++++++++++++++++-----
 sys/vfs/nfs/nfsmount.h     |    2 +
 10 files changed, 324 insertions(+), 75 deletions(-)

http://gitweb.dragonflybsd.org/dragonfly.git/commitdiff/c6b43e93a6cf0a70bde32cd141057a0df9860e13


-- 
DragonFly BSD source repository





More information about the Commits mailing list