vfs: Abstract rcu_dereference_check for files-fdtable use
authorPaul E. McKenney <[email protected]>
Tue, 23 Feb 2010 01:04:53 +0000 (17:04 -0800)
committerIngo Molnar <[email protected]>
Thu, 25 Feb 2010 09:34:49 +0000 (10:34 +0100)
Create an rcu_dereference_check_fdtable() that encapsulates the
rcu_dereference_check() condition for fcheck_files() use.  This
has the beneficial side-effect of getting rid of a very long
line.

Suggested-by: Peter Zijlstra <[email protected]>
Signed-off-by: Paul E. McKenney <[email protected]>
Cc: [email protected]
Cc: [email protected]
Cc: [email protected]
Cc: [email protected]
Cc: [email protected]
Cc: [email protected]
Cc: [email protected]
Cc: [email protected]
Cc: [email protected]
Cc: [email protected]
LKML-Reference: <1266887105[email protected]>
Signed-off-by: Ingo Molnar <[email protected]>
include/linux/fdtable.h

index 144412ffaced1aee404b2d72df5023badb3f770e..013dc529e95ffc43121fbf8cfbac9d432fa29bc6 100644 (file)
@@ -57,11 +57,14 @@ struct files_struct {
        struct file * fd_array[NR_OPEN_DEFAULT];
 };
 
-#define files_fdtable(files) \
-       (rcu_dereference_check((files)->fdt, \
+#define rcu_dereference_check_fdtable(files, fdtfd) \
+       (rcu_dereference_check((fdtfd), \
                               rcu_read_lock_held() || \
                               lockdep_is_held(&(files)->file_lock) || \
-                              atomic_read(&files->count) == 1))
+                              atomic_read(&(files)->count) == 1))
+
+#define files_fdtable(files) \
+               (rcu_dereference_check_fdtable((files), (files)->fdt))
 
 struct file_operations;
 struct vfsmount;
@@ -82,7 +85,7 @@ static inline struct file * fcheck_files(struct files_struct *files, unsigned in
        struct fdtable *fdt = files_fdtable(files);
 
        if (fd < fdt->max_fds)
-               file = rcu_dereference_check(fdt->fd[fd], rcu_read_lock_held() || lockdep_is_held(&files->file_lock) || atomic_read(&files->count) == 1);
+               file = rcu_dereference_check_fdtable(files, fdt->fd[fd]);
        return file;
 }