Blame view

include/linux/fdtable.h 2.59 KB
9f3acc314   Al Viro   [PATCH] split lin...
1
2
3
4
5
6
  /*
   * descriptor table internals; you almost certainly want file.h instead.
   */
  
  #ifndef __LINUX_FDTABLE_H
  #define __LINUX_FDTABLE_H
9f3acc314   Al Viro   [PATCH] split lin...
7
8
9
10
11
  #include <linux/posix_types.h>
  #include <linux/compiler.h>
  #include <linux/spinlock.h>
  #include <linux/rcupdate.h>
  #include <linux/types.h>
21e544592   Ingo Molnar   kmemtrace, fs: fi...
12
  #include <linux/init.h>
2c666df80   Paul E. McKenney   vfs: add fs.h to ...
13
  #include <linux/fs.h>
21e544592   Ingo Molnar   kmemtrace, fs: fi...
14
15
  
  #include <asm/atomic.h>
9f3acc314   Al Viro   [PATCH] split lin...
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
  
  /*
   * The default fd array needs to be at least BITS_PER_LONG,
   * as this is the granularity returned by copy_fdset().
   */
  #define NR_OPEN_DEFAULT BITS_PER_LONG
  
  /*
   * The embedded_fd_set is a small fd_set,
   * suitable for most tasks (which open <= BITS_PER_LONG files)
   */
  struct embedded_fd_set {
  	unsigned long fds_bits[1];
  };
  
  struct fdtable {
  	unsigned int max_fds;
  	struct file ** fd;      /* current fd array */
  	fd_set *close_on_exec;
  	fd_set *open_fds;
  	struct rcu_head rcu;
  	struct fdtable *next;
  };
  
  /*
   * Open file table structure
   */
  struct files_struct {
    /*
     * read mostly part
     */
  	atomic_t count;
  	struct fdtable *fdt;
  	struct fdtable fdtab;
    /*
     * written part on a separate cache line in SMP
     */
  	spinlock_t file_lock ____cacheline_aligned_in_smp;
  	int next_fd;
  	struct embedded_fd_set close_on_exec_init;
  	struct embedded_fd_set open_fds_init;
  	struct file * fd_array[NR_OPEN_DEFAULT];
  };
af61b96b4   Paul E. McKenney   vfs: Abstract rcu...
59
60
  #define rcu_dereference_check_fdtable(files, fdtfd) \
  	(rcu_dereference_check((fdtfd), \
7dc521579   Paul E. McKenney   vfs: Apply lockde...
61
62
  			       rcu_read_lock_held() || \
  			       lockdep_is_held(&(files)->file_lock) || \
844b9a870   Paul E. McKenney   vfs: fix RCU-lock...
63
64
  			       atomic_read(&(files)->count) == 1 || \
  			       rcu_my_thread_group_empty()))
af61b96b4   Paul E. McKenney   vfs: Abstract rcu...
65
66
67
  
  #define files_fdtable(files) \
  		(rcu_dereference_check_fdtable((files), (files)->fdt))
9f3acc314   Al Viro   [PATCH] split lin...
68

9f3acc314   Al Viro   [PATCH] split lin...
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
  struct file_operations;
  struct vfsmount;
  struct dentry;
  
  extern int expand_files(struct files_struct *, int nr);
  extern void free_fdtable_rcu(struct rcu_head *rcu);
  extern void __init files_defer_init(void);
  
  static inline void free_fdtable(struct fdtable *fdt)
  {
  	call_rcu(&fdt->rcu, free_fdtable_rcu);
  }
  
  static inline struct file * fcheck_files(struct files_struct *files, unsigned int fd)
  {
  	struct file * file = NULL;
  	struct fdtable *fdt = files_fdtable(files);
  
  	if (fd < fdt->max_fds)
af61b96b4   Paul E. McKenney   vfs: Abstract rcu...
88
  		file = rcu_dereference_check_fdtable(files, fdt->fd[fd]);
9f3acc314   Al Viro   [PATCH] split lin...
89
90
91
92
93
94
95
96
97
98
99
100
101
102
  	return file;
  }
  
  /*
   * Check whether the specified fd has an open file.
   */
  #define fcheck(fd)	fcheck_files(current->files, fd)
  
  struct task_struct;
  
  struct files_struct *get_files_struct(struct task_struct *);
  void put_files_struct(struct files_struct *fs);
  void reset_files_struct(struct files_struct *);
  int unshare_files(struct files_struct **);
02afc6267   Al Viro   [PATCH] dup_fd() ...
103
  struct files_struct *dup_fd(struct files_struct *, int *);
9f3acc314   Al Viro   [PATCH] split lin...
104
105
106
107
  
  extern struct kmem_cache *files_cachep;
  
  #endif /* __LINUX_FDTABLE_H */