diff options
author | Arnd Bergmann <arnd@arndb.de> | 2010-09-16 09:35:54 -0400 |
---|---|---|
committer | Arnd Bergmann <arnd@arndb.de> | 2010-10-04 15:10:48 -0400 |
commit | 18dfe89d7c394b56e20e06dde8b7a80ff96cf02c (patch) | |
tree | bcf8dee4faffd32cc5cfec2febe40f145d0c23aa | |
parent | 77f2fe036cd51300c80d1aca76bcf23a09977f13 (diff) |
BKL: Remove BKL from ecryptfs
The BKL is only used in fill_super, which is protected by the superblocks
s_umount rw_semaphorei, and in fasync, which does not do anything that
could require the BKL. Therefore it is safe to remove the BKL entirely.
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Cc: Dustin Kirkland <kirkland@canonical.com>
Cc: Tyler Hicks <tyhicks@linux.vnet.ibm.com>
Cc: ecryptfs-devel@lists.launchpad.net
-rw-r--r-- | fs/ecryptfs/file.c | 3 | ||||
-rw-r--r-- | fs/ecryptfs/main.c | 4 |
2 files changed, 0 insertions, 7 deletions
diff --git a/fs/ecryptfs/file.c b/fs/ecryptfs/file.c index 622c95140802..2b9a644b7583 100644 --- a/fs/ecryptfs/file.c +++ b/fs/ecryptfs/file.c | |||
@@ -31,7 +31,6 @@ | |||
31 | #include <linux/security.h> | 31 | #include <linux/security.h> |
32 | #include <linux/compat.h> | 32 | #include <linux/compat.h> |
33 | #include <linux/fs_stack.h> | 33 | #include <linux/fs_stack.h> |
34 | #include <linux/smp_lock.h> | ||
35 | #include "ecryptfs_kernel.h" | 34 | #include "ecryptfs_kernel.h" |
36 | 35 | ||
37 | /** | 36 | /** |
@@ -284,11 +283,9 @@ static int ecryptfs_fasync(int fd, struct file *file, int flag) | |||
284 | int rc = 0; | 283 | int rc = 0; |
285 | struct file *lower_file = NULL; | 284 | struct file *lower_file = NULL; |
286 | 285 | ||
287 | lock_kernel(); | ||
288 | lower_file = ecryptfs_file_to_lower(file); | 286 | lower_file = ecryptfs_file_to_lower(file); |
289 | if (lower_file->f_op && lower_file->f_op->fasync) | 287 | if (lower_file->f_op && lower_file->f_op->fasync) |
290 | rc = lower_file->f_op->fasync(fd, lower_file, flag); | 288 | rc = lower_file->f_op->fasync(fd, lower_file, flag); |
291 | unlock_kernel(); | ||
292 | return rc; | 289 | return rc; |
293 | } | 290 | } |
294 | 291 | ||
diff --git a/fs/ecryptfs/main.c b/fs/ecryptfs/main.c index c4af92fa12c3..cbd4e18adb20 100644 --- a/fs/ecryptfs/main.c +++ b/fs/ecryptfs/main.c | |||
@@ -36,7 +36,6 @@ | |||
36 | #include <linux/parser.h> | 36 | #include <linux/parser.h> |
37 | #include <linux/fs_stack.h> | 37 | #include <linux/fs_stack.h> |
38 | #include <linux/slab.h> | 38 | #include <linux/slab.h> |
39 | #include <linux/smp_lock.h> /* For lock_kernel() */ | ||
40 | #include "ecryptfs_kernel.h" | 39 | #include "ecryptfs_kernel.h" |
41 | 40 | ||
42 | /** | 41 | /** |
@@ -551,7 +550,6 @@ static int ecryptfs_get_sb(struct file_system_type *fs_type, int flags, | |||
551 | const char *err = "Getting sb failed"; | 550 | const char *err = "Getting sb failed"; |
552 | int rc; | 551 | int rc; |
553 | 552 | ||
554 | lock_kernel(); | ||
555 | sbi = kmem_cache_zalloc(ecryptfs_sb_info_cache, GFP_KERNEL); | 553 | sbi = kmem_cache_zalloc(ecryptfs_sb_info_cache, GFP_KERNEL); |
556 | if (!sbi) { | 554 | if (!sbi) { |
557 | rc = -ENOMEM; | 555 | rc = -ENOMEM; |
@@ -610,7 +608,6 @@ static int ecryptfs_get_sb(struct file_system_type *fs_type, int flags, | |||
610 | goto out; | 608 | goto out; |
611 | } | 609 | } |
612 | simple_set_mnt(mnt, s); | 610 | simple_set_mnt(mnt, s); |
613 | unlock_kernel(); | ||
614 | return 0; | 611 | return 0; |
615 | 612 | ||
616 | out: | 613 | out: |
@@ -619,7 +616,6 @@ out: | |||
619 | kmem_cache_free(ecryptfs_sb_info_cache, sbi); | 616 | kmem_cache_free(ecryptfs_sb_info_cache, sbi); |
620 | } | 617 | } |
621 | printk(KERN_ERR "%s; rc = [%d]\n", err, rc); | 618 | printk(KERN_ERR "%s; rc = [%d]\n", err, rc); |
622 | unlock_kernel(); | ||
623 | return rc; | 619 | return rc; |
624 | } | 620 | } |
625 | 621 | ||