Author: kib
Date: Sun Feb 28 17:13:07 2010
New Revision: 204470
URL: http://svn.freebsd.org/changeset/base/204470

Log:
  Add per-mountpoint lockmgr lock for msdosfs. It is intended to be used
  as fat bitmap lock and to replace global mutex protecting fileno rbtree.
  
  Tested by:    pho
  MFC after:    3 weeks

Modified:
  head/sys/fs/msdosfs/msdosfs_vfsops.c
  head/sys/fs/msdosfs/msdosfsmount.h

Modified: head/sys/fs/msdosfs/msdosfs_vfsops.c
==============================================================================
--- head/sys/fs/msdosfs/msdosfs_vfsops.c        Sun Feb 28 17:11:31 2010        
(r204469)
+++ head/sys/fs/msdosfs/msdosfs_vfsops.c        Sun Feb 28 17:13:07 2010        
(r204470)
@@ -75,6 +75,8 @@
 #include <fs/msdosfs/fat.h>
 #include <fs/msdosfs/msdosfsmount.h>
 
+static const char msdosfs_lock_msg[] = "fatlk";
+
 /* Mount options that we support. */
 static const char *msdosfs_opts[] = {
        "async", "noatime", "noclusterr", "noclusterw",
@@ -466,6 +468,8 @@ mountmsdosfs(struct vnode *devvp, struct
        pmp->pm_cp = cp;
        pmp->pm_bo = bo;
 
+       lockinit(&pmp->pm_fatlock, 0, msdosfs_lock_msg, 0, 0);
+
        /*
         * Initialize ownerships and permissions, since nothing else will
         * initialize them iff we are mounting root.
@@ -762,6 +766,7 @@ error_exit:
                g_topology_unlock();
                PICKUP_GIANT();
        }
+       lockdestroy(&pmp->pm_fatlock);
        if (pmp) {
                if (pmp->pm_inusemap)
                        free(pmp->pm_inusemap, M_MSDOSFSFAT);
@@ -837,6 +842,7 @@ msdosfs_unmount(struct mount *mp, int mn
        free(pmp->pm_inusemap, M_MSDOSFSFAT);
        if (pmp->pm_flags & MSDOSFS_LARGEFS)
                msdosfs_fileno_free(mp);
+       lockdestroy(&pmp->pm_fatlock);
        free(pmp, M_MSDOSFSMNT);
        mp->mnt_data = NULL;
        MNT_ILOCK(mp);

Modified: head/sys/fs/msdosfs/msdosfsmount.h
==============================================================================
--- head/sys/fs/msdosfs/msdosfsmount.h  Sun Feb 28 17:11:31 2010        
(r204469)
+++ head/sys/fs/msdosfs/msdosfsmount.h  Sun Feb 28 17:13:07 2010        
(r204470)
@@ -53,6 +53,9 @@
 
 #ifdef _KERNEL
 
+#include <sys/types.h>
+#include <sys/lock.h>
+#include <sys/lockmgr.h>
 #include <sys/tree.h>
 
 #ifdef MALLOC_DECLARE
@@ -106,7 +109,9 @@ struct msdosfsmount {
        void *pm_u2d;   /* Unicode->DOS iconv handle */
        void *pm_d2u;   /* DOS->Local iconv handle */
        u_int32_t pm_nfileno;   /* next 32-bit fileno */
-       RB_HEAD(msdosfs_filenotree, msdosfs_fileno) pm_filenos; /* 64<->32-bit 
fileno mapping */
+       RB_HEAD(msdosfs_filenotree, msdosfs_fileno)
+           pm_filenos; /* 64<->32-bit fileno mapping */
+       struct lock pm_fatlock; /* lockmgr protecting allocations and rb tree */
 };
 
 /*
@@ -215,6 +220,13 @@ void msdosfs_fileno_init(struct mount *)
 void msdosfs_fileno_free(struct mount *);
 uint32_t msdosfs_fileno_map(struct mount *, uint64_t);
 
+#define        MSDOSFS_LOCK_MP(pmp) \
+       lockmgr(&(pmp)->pm_fatlock, LK_EXCLUSIVE, NULL)
+#define        MSDOSFS_UNLOCK_MP(pmp) \
+       lockmgr(&(pmp)->pm_fatlock, LK_RELEASE, NULL)
+#define        MSDOSFS_ASSERT_MP_LOCKED(pmp) \
+       lockmgr_assert(&(pmp)->pm_fatlock, KA_XLOCKED)
+
 #endif /* _KERNEL */
 
 /*
_______________________________________________
svn-src-head@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "svn-src-head-unsubscr...@freebsd.org"

Reply via email to