]> git.proxmox.com Git - mirror_ubuntu-zesty-kernel.git/blame - fs/internal.h
fs: Improve filesystem freezing handling
[mirror_ubuntu-zesty-kernel.git] / fs / internal.h
CommitLineData
07f3f05c
DH
1/* fs/ internal definitions
2 *
3 * Copyright (C) 2006 Red Hat, Inc. All Rights Reserved.
4 * Written by David Howells (dhowells@redhat.com)
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * as published by the Free Software Foundation; either version
9 * 2 of the License, or (at your option) any later version.
10 */
11
99b7db7b
NP
12#include <linux/lglock.h>
13
5e6d12b2 14struct super_block;
9d412a43 15struct file_system_type;
a6f76f23 16struct linux_binprm;
3e93cd67 17struct path;
c7105365 18struct mount;
5e6d12b2 19
07f3f05c
DH
20/*
21 * block_dev.c
22 */
9361401e 23#ifdef CONFIG_BLOCK
07f3f05c
DH
24extern void __init bdev_cache_init(void);
25
5cee5815
JK
26extern int __sync_blockdev(struct block_device *bdev, int wait);
27
9361401e 28#else
5e6d12b2
AM
29static inline void bdev_cache_init(void)
30{
31}
9361401e 32
5cee5815
JK
33static inline int __sync_blockdev(struct block_device *bdev, int wait)
34{
35 return 0;
36}
9361401e 37#endif
7b0de42d 38
07f3f05c
DH
39/*
40 * char_dev.c
41 */
42extern void __init chrdev_init(void);
43
0bdaea90
DH
44/*
45 * namei.c
46 */
47extern int __inode_permission(struct inode *, int);
48
07f3f05c
DH
49/*
50 * namespace.c
51 */
52extern int copy_mount_options(const void __user *, unsigned long *);
eca6f534 53extern int copy_mount_string(const void __user *, char **);
6d59e7f5 54
0f60f240 55extern struct vfsmount *lookup_mnt(struct path *);
19a167af 56extern int finish_automount(struct vfsmount *, struct path *);
6d59e7f5 57
4ed5e82f 58extern int sb_prepare_remount_readonly(struct super_block *);
f03c6599 59
6d59e7f5 60extern void __init mnt_init(void);
3e93cd67 61
eea62f83 62extern struct lglock vfsmount_lock;
99b7db7b 63
47cd813f 64
3e93cd67
AV
65/*
66 * fs_struct.c
67 */
68extern void chroot_fs_refs(struct path *, struct path *);
864d7c4c 69
70/*
71 * file_table.c
72 */
d996b62a
NP
73extern void file_sb_list_add(struct file *f, struct super_block *sb);
74extern void file_sb_list_del(struct file *f);
864d7c4c 75extern void mark_files_ro(struct super_block *);
e81e3f4d 76extern struct file *get_empty_filp(void);
62c6943b
AV
77
78/*
79 * super.c
80 */
81extern int do_remount_sb(struct super_block *, int, void *, int);
12ad3ab6 82extern bool grab_super_passive(struct super_block *sb);
9d412a43
AV
83extern struct dentry *mount_fs(struct file_system_type *,
84 int, const char *, void *);
cf31e70d 85extern struct super_block *user_get_super(dev_t);
482928d5
AV
86
87/*
88 * open.c
89 */
47c805dc
AV
90struct open_flags {
91 int open_flag;
a218d0fd 92 umode_t mode;
47c805dc
AV
93 int acc_mode;
94 int intent;
95};
96extern struct file *do_filp_open(int dfd, const char *pathname,
97 const struct open_flags *op, int lookup_flags);
73d049a4
AV
98extern struct file *do_file_open_root(struct dentry *, struct vfsmount *,
99 const char *, const struct open_flags *, int lookup_flags);
a8dade34 100
becfd1f3
AK
101extern long do_handle_open(int mountdirfd,
102 struct file_handle __user *ufh, int open_flag);
90ad1a8e 103extern int open_check_o_direct(struct file *f);
becfd1f3 104
a8dade34
AV
105/*
106 * inode.c
107 */
55fa6091
DC
108extern spinlock_t inode_sb_list_lock;
109
a66979ab
DC
110/*
111 * fs-writeback.c
112 */
113extern void inode_wb_list_del(struct inode *inode);
114
cffbc8aa 115extern int get_nr_dirty_inodes(void);
a4cdbd8b 116extern void evict_inodes(struct super_block *);
93b270f7 117extern int invalidate_inodes(struct super_block *, bool);
a4464dbc
AV
118
119/*
120 * dcache.c
121 */
122extern struct dentry *__d_alloc(struct super_block *, const struct qstr *);