Revert to Fedora kernel-2.6.17-1.2187_FC5 patched with vs2.0.2.1; there are too many...
[linux-2.6.git] / fs / ntfs / super.c
index 74e0ee8..27833f6 100644 (file)
@@ -1724,14 +1724,6 @@ upcase_failed:
        return FALSE;
 }
 
-/*
- * The lcn and mft bitmap inodes are NTFS-internal inodes with
- * their own special locking rules:
- */
-static struct lock_class_key
-       lcnbmp_runlist_lock_key, lcnbmp_mrec_lock_key,
-       mftbmp_runlist_lock_key, mftbmp_mrec_lock_key;
-
 /**
  * load_system_files - open the system files using normal functions
  * @vol:       ntfs super block describing device whose system files to load
@@ -1788,10 +1780,6 @@ static BOOL load_system_files(ntfs_volume *vol)
                ntfs_error(sb, "Failed to load $MFT/$BITMAP attribute.");
                goto iput_mirr_err_out;
        }
-       lockdep_set_class(&NTFS_I(vol->mftbmp_ino)->runlist.lock,
-                          &mftbmp_runlist_lock_key);
-       lockdep_set_class(&NTFS_I(vol->mftbmp_ino)->mrec_lock,
-                          &mftbmp_mrec_lock_key);
        /* Read upcase table and setup @vol->upcase and @vol->upcase_len. */
        if (!load_and_init_upcase(vol))
                goto iput_mftbmp_err_out;
@@ -1814,11 +1802,6 @@ static BOOL load_system_files(ntfs_volume *vol)
                        iput(vol->lcnbmp_ino);
                goto bitmap_failed;
        }
-       lockdep_set_class(&NTFS_I(vol->lcnbmp_ino)->runlist.lock,
-                          &lcnbmp_runlist_lock_key);
-       lockdep_set_class(&NTFS_I(vol->lcnbmp_ino)->mrec_lock,
-                          &lcnbmp_mrec_lock_key);
-
        NInoSetSparseDisabled(NTFS_I(vol->lcnbmp_ino));
        if ((vol->nr_clusters + 7) >> 3 > i_size_read(vol->lcnbmp_ino)) {
                iput(vol->lcnbmp_ino);
@@ -2618,10 +2601,10 @@ static unsigned long __get_nr_free_mft_records(ntfs_volume *vol,
 
 /**
  * ntfs_statfs - return information about mounted NTFS volume
- * @dentry:    dentry from mounted volume
+ * @sb:                super block of mounted volume
  * @sfs:       statfs structure in which to return the information
  *
- * Return information about the mounted NTFS volume @dentry in the statfs structure
+ * Return information about the mounted NTFS volume @sb in the statfs structure
  * pointed to by @sfs (this is initialized with zeros before ntfs_statfs is
  * called). We interpret the values to be correct of the moment in time at
  * which we are called. Most values are variable otherwise and this isn't just
@@ -2634,9 +2617,8 @@ static unsigned long __get_nr_free_mft_records(ntfs_volume *vol,
  *
  * Return 0 on success or -errno on error.
  */
-static int ntfs_statfs(struct dentry *dentry, struct kstatfs *sfs)
+static int ntfs_statfs(struct super_block *sb, struct kstatfs *sfs)
 {
-       struct super_block *sb = dentry->d_sb;
        s64 size;
        ntfs_volume *vol = NTFS_SB(sb);
        ntfs_inode *mft_ni = NTFS_I(vol->mft_ino);
@@ -2760,17 +2742,6 @@ static int ntfs_fill_super(struct super_block *sb, void *opt, const int silent)
        struct inode *tmp_ino;
        int blocksize, result;
 
-       /*
-        * We do a pretty difficult piece of bootstrap by reading the
-        * MFT (and other metadata) from disk into memory. We'll only
-        * release this metadata during umount, so the locking patterns
-        * observed during bootstrap do not count. So turn off the
-        * observation of locking patterns (strictly for this context
-        * only) while mounting NTFS. [The validator is still active
-        * otherwise, even for this context: it will for example record
-        * lock class registrations.]
-        */
-       lockdep_off();
        ntfs_debug("Entering.");
 #ifndef NTFS_RW
        sb->s_flags |= MS_RDONLY;
@@ -2782,7 +2753,6 @@ static int ntfs_fill_super(struct super_block *sb, void *opt, const int silent)
                if (!silent)
                        ntfs_error(sb, "Allocation of NTFS volume structure "
                                        "failed. Aborting mount...");
-               lockdep_on();
                return -ENOMEM;
        }
        /* Initialize ntfs_volume structure. */
@@ -2969,7 +2939,6 @@ static int ntfs_fill_super(struct super_block *sb, void *opt, const int silent)
                mutex_unlock(&ntfs_lock);
                sb->s_export_op = &ntfs_export_ops;
                lock_kernel();
-               lockdep_on();
                return 0;
        }
        ntfs_error(sb, "Failed to allocate root directory.");
@@ -3089,7 +3058,6 @@ err_out_now:
        sb->s_fs_info = NULL;
        kfree(vol);
        ntfs_debug("Failed, returning -EINVAL.");
-       lockdep_on();
        return -EINVAL;
 }
 
@@ -3125,11 +3093,10 @@ struct kmem_cache *ntfs_index_ctx_cache;
 /* Driver wide mutex. */
 DEFINE_MUTEX(ntfs_lock);
 
-static int ntfs_get_sb(struct file_system_type *fs_type,
-       int flags, const char *dev_name, void *data, struct vfsmount *mnt)
+static struct super_block *ntfs_get_sb(struct file_system_type *fs_type,
+       int flags, const char *dev_name, void *data)
 {
-       return get_sb_bdev(fs_type, flags, dev_name, data, ntfs_fill_super,
-                          mnt);
+       return get_sb_bdev(fs_type, flags, dev_name, data, ntfs_fill_super);
 }
 
 static struct file_system_type ntfs_fs_type = {