Commit | Line | Data |
---|---|---|
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 | ||
5e6d12b2 | 12 | struct super_block; |
9d412a43 | 13 | struct file_system_type; |
ae259a9c | 14 | struct iomap; |
befb503c | 15 | struct iomap_ops; |
a6f76f23 | 16 | struct linux_binprm; |
3e93cd67 | 17 | struct path; |
c7105365 | 18 | struct mount; |
503c358c | 19 | struct shrink_control; |
5e6d12b2 | 20 | |
07f3f05c DH |
21 | /* |
22 | * block_dev.c | |
23 | */ | |
9361401e | 24 | #ifdef CONFIG_BLOCK |
07f3f05c DH |
25 | extern void __init bdev_cache_init(void); |
26 | ||
5cee5815 JK |
27 | extern int __sync_blockdev(struct block_device *bdev, int wait); |
28 | ||
9361401e | 29 | #else |
5e6d12b2 AM |
30 | static inline void bdev_cache_init(void) |
31 | { | |
32 | } | |
9361401e | 33 | |
5cee5815 JK |
34 | static inline int __sync_blockdev(struct block_device *bdev, int wait) |
35 | { | |
36 | return 0; | |
37 | } | |
9361401e | 38 | #endif |
7b0de42d | 39 | |
4db96b71 AM |
40 | /* |
41 | * buffer.c | |
42 | */ | |
43 | extern void guard_bio_eod(int rw, struct bio *bio); | |
ae259a9c CH |
44 | extern int __block_write_begin_int(struct page *page, loff_t pos, unsigned len, |
45 | get_block_t *get_block, struct iomap *iomap); | |
a6d639da CH |
46 | int __generic_write_end(struct inode *inode, loff_t pos, unsigned copied, |
47 | struct page *page); | |
4db96b71 | 48 | |
07f3f05c DH |
49 | /* |
50 | * char_dev.c | |
51 | */ | |
52 | extern void __init chrdev_init(void); | |
53 | ||
0bdaea90 DH |
54 | /* |
55 | * namei.c | |
56 | */ | |
197df04c AV |
57 | extern int user_path_mountpoint_at(int, const char __user *, unsigned int, struct path *); |
58 | extern int vfs_path_lookup(struct dentry *, struct vfsmount *, | |
59 | const char *, unsigned int, struct path *); | |
87c4e192 DB |
60 | long do_mknodat(int dfd, const char __user *filename, umode_t mode, |
61 | unsigned int dev); | |
0101db7a | 62 | long do_mkdirat(int dfd, const char __user *pathname, umode_t mode); |
f459dffa | 63 | long do_rmdir(int dfd, const char __user *pathname); |
da2f1362 | 64 | long do_unlinkat(int dfd, struct filename *name); |
b724e846 DB |
65 | long do_symlinkat(const char __user *oldname, int newdfd, |
66 | const char __user *newname); | |
46ea89eb DB |
67 | int do_linkat(int olddfd, const char __user *oldname, int newdfd, |
68 | const char __user *newname, int flags); | |
0bdaea90 | 69 | |
07f3f05c DH |
70 | /* |
71 | * namespace.c | |
72 | */ | |
b40ef869 | 73 | extern void *copy_mount_options(const void __user *); |
b8850d1f | 74 | extern char *copy_mount_string(const void __user *); |
6d59e7f5 | 75 | |
ca71cf71 | 76 | extern struct vfsmount *lookup_mnt(const struct path *); |
19a167af | 77 | extern int finish_automount(struct vfsmount *, struct path *); |
6d59e7f5 | 78 | |
4ed5e82f | 79 | extern int sb_prepare_remount_readonly(struct super_block *); |
f03c6599 | 80 | |
6d59e7f5 | 81 | extern void __init mnt_init(void); |
3e93cd67 | 82 | |
eb04c282 JK |
83 | extern int __mnt_want_write(struct vfsmount *); |
84 | extern int __mnt_want_write_file(struct file *); | |
7c6893e3 | 85 | extern int mnt_want_write_file_path(struct file *); |
eb04c282 JK |
86 | extern void __mnt_drop_write(struct vfsmount *); |
87 | extern void __mnt_drop_write_file(struct file *); | |
7c6893e3 | 88 | extern void mnt_drop_write_file_path(struct file *); |
47cd813f | 89 | |
3e93cd67 AV |
90 | /* |
91 | * fs_struct.c | |
92 | */ | |
dcf787f3 | 93 | extern void chroot_fs_refs(const struct path *, const struct path *); |
864d7c4c | 94 | |
95 | /* | |
96 | * file_table.c | |
97 | */ | |
ea73ea72 | 98 | extern struct file *alloc_empty_file(int, const struct cred *); |
62c6943b AV |
99 | |
100 | /* | |
101 | * super.c | |
102 | */ | |
103 | extern int do_remount_sb(struct super_block *, int, void *, int); | |
eb6ef3df | 104 | extern bool trylock_super(struct super_block *sb); |
9d412a43 AV |
105 | extern struct dentry *mount_fs(struct file_system_type *, |
106 | int, const char *, void *); | |
cf31e70d | 107 | extern struct super_block *user_get_super(dev_t); |
482928d5 AV |
108 | |
109 | /* | |
110 | * open.c | |
111 | */ | |
47c805dc AV |
112 | struct open_flags { |
113 | int open_flag; | |
a218d0fd | 114 | umode_t mode; |
47c805dc AV |
115 | int acc_mode; |
116 | int intent; | |
f9652e10 | 117 | int lookup_flags; |
47c805dc | 118 | }; |
669abf4e | 119 | extern struct file *do_filp_open(int dfd, struct filename *pathname, |
f9652e10 | 120 | const struct open_flags *op); |
73d049a4 | 121 | extern struct file *do_file_open_root(struct dentry *, struct vfsmount *, |
f9652e10 | 122 | const char *, const struct open_flags *); |
a8dade34 | 123 | |
411d9475 | 124 | long do_sys_ftruncate(unsigned int fd, loff_t length, int small); |
cbfe20f5 | 125 | long do_faccessat(int dfd, const char __user *filename, int mode); |
03450e27 | 126 | int do_fchmodat(int dfd, const char __user *filename, umode_t mode); |
55731b3c DB |
127 | int do_fchownat(int dfd, const char __user *filename, uid_t user, gid_t group, |
128 | int flag); | |
03450e27 | 129 | |
ae2bb293 | 130 | extern int vfs_open(const struct path *, struct file *); |
becfd1f3 | 131 | |
a8dade34 AV |
132 | /* |
133 | * inode.c | |
134 | */ | |
503c358c | 135 | extern long prune_icache_sb(struct super_block *sb, struct shrink_control *sc); |
4eff96dd | 136 | extern void inode_add_lru(struct inode *inode); |
f0fce87c | 137 | extern int dentry_needs_remove_privs(struct dentry *dentry); |
55fa6091 | 138 | |
598e3c8f MS |
139 | extern bool __atime_needs_update(const struct path *, struct inode *, bool); |
140 | static inline bool atime_needs_update_rcu(const struct path *path, | |
141 | struct inode *inode) | |
142 | { | |
143 | return __atime_needs_update(path, inode, true); | |
144 | } | |
145 | ||
a66979ab DC |
146 | /* |
147 | * fs-writeback.c | |
148 | */ | |
c7f54084 | 149 | extern void inode_io_list_del(struct inode *inode); |
a66979ab | 150 | |
3942c07c | 151 | extern long get_nr_dirty_inodes(void); |
93b270f7 | 152 | extern int invalidate_inodes(struct super_block *, bool); |
a4464dbc AV |
153 | |
154 | /* | |
155 | * dcache.c | |
156 | */ | |
157 | extern struct dentry *__d_alloc(struct super_block *, const struct qstr *); | |
eed81007 | 158 | extern int d_set_mounted(struct dentry *dentry); |
503c358c | 159 | extern long prune_dcache_sb(struct super_block *sb, struct shrink_control *sc); |
ba65dc5e | 160 | extern struct dentry *d_alloc_cursor(struct dentry *); |
06ae43f3 AV |
161 | |
162 | /* | |
163 | * read_write.c | |
164 | */ | |
68d70d03 | 165 | extern int rw_verify_area(int, struct file *, const loff_t *, size_t); |
599a0ac1 AV |
166 | |
167 | /* | |
168 | * pipe.c | |
169 | */ | |
170 | extern const struct file_operations pipefifo_fops; | |
8fa1f1c2 AV |
171 | |
172 | /* | |
173 | * fs_pin.c | |
174 | */ | |
fdab684d | 175 | extern void group_pin_kill(struct hlist_head *p); |
8fa1f1c2 | 176 | extern void mnt_pin_kill(struct mount *m); |
e149ed2b AV |
177 | |
178 | /* | |
179 | * fs/nsfs.c | |
180 | */ | |
be218aa2 | 181 | extern const struct dentry_operations ns_dentry_operations; |
66cf191f AV |
182 | |
183 | /* | |
184 | * fs/ioctl.c | |
185 | */ | |
186 | extern int do_vfs_ioctl(struct file *file, unsigned int fd, unsigned int cmd, | |
187 | unsigned long arg); | |
188 | extern long vfs_ioctl(struct file *file, unsigned int cmd, unsigned long arg); | |
befb503c CH |
189 | |
190 | /* | |
191 | * iomap support: | |
192 | */ | |
193 | typedef loff_t (*iomap_actor_t)(struct inode *inode, loff_t pos, loff_t len, | |
194 | void *data, struct iomap *iomap); | |
195 | ||
196 | loff_t iomap_apply(struct inode *inode, loff_t pos, loff_t length, | |
8ff6daa1 | 197 | unsigned flags, const struct iomap_ops *ops, void *data, |
befb503c | 198 | iomap_actor_t actor); |
ec1b8260 CH |
199 | |
200 | /* direct-io.c: */ | |
201 | int sb_init_dio_done_wq(struct super_block *sb); |