consolidate the reassignments of ->f_op in ->open() instances
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
parent
7b00ed6fe6
commit
e84f9e57b9
8 changed files with 43 additions and 77 deletions
|
|
@ -1875,6 +1875,17 @@ extern struct dentry *mount_pseudo(struct file_system_type *, char *,
|
|||
(((fops) && try_module_get((fops)->owner) ? (fops) : NULL))
|
||||
#define fops_put(fops) \
|
||||
do { if (fops) module_put((fops)->owner); } while(0)
|
||||
/*
|
||||
* This one is to be used *ONLY* from ->open() instances.
|
||||
* fops must be non-NULL, pinned down *and* module dependencies
|
||||
* should be sufficient to pin the caller down as well.
|
||||
*/
|
||||
#define replace_fops(f, fops) \
|
||||
do { \
|
||||
struct file *__file = (f); \
|
||||
fops_put(__file->f_op); \
|
||||
BUG_ON(!(__file->f_op = (fops))); \
|
||||
} while(0)
|
||||
|
||||
extern int register_filesystem(struct file_system_type *);
|
||||
extern int unregister_filesystem(struct file_system_type *);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue