]>
Commit | Line | Data |
---|---|---|
2874c5fd | 1 | /* SPDX-License-Identifier: GPL-2.0-or-later */ |
07f3f05c DH |
2 | /* fs/ internal definitions |
3 | * | |
4 | * Copyright (C) 2006 Red Hat, Inc. All Rights Reserved. | |
5 | * Written by David Howells ([email protected]) | |
07f3f05c DH |
6 | */ |
7 | ||
5e6d12b2 | 8 | struct super_block; |
9d412a43 | 9 | struct file_system_type; |
ae259a9c | 10 | struct iomap; |
befb503c | 11 | struct iomap_ops; |
a6f76f23 | 12 | struct linux_binprm; |
3e93cd67 | 13 | struct path; |
c7105365 | 14 | struct mount; |
503c358c | 15 | struct shrink_control; |
9bc61ab1 | 16 | struct fs_context; |
2527b284 | 17 | struct user_namespace; |
5e6d12b2 | 18 | |
07f3f05c DH |
19 | /* |
20 | * block_dev.c | |
21 | */ | |
9361401e | 22 | #ifdef CONFIG_BLOCK |
07f3f05c DH |
23 | extern void __init bdev_cache_init(void); |
24 | ||
5cee5815 | 25 | extern int __sync_blockdev(struct block_device *bdev, int wait); |
3f1266f1 CH |
26 | void iterate_bdevs(void (*)(struct block_device *, void *), void *); |
27 | void emergency_thaw_bdev(struct super_block *sb); | |
9361401e | 28 | #else |
5e6d12b2 AM |
29 | static inline void bdev_cache_init(void) |
30 | { | |
31 | } | |
9361401e | 32 | |
5cee5815 JK |
33 | static inline int __sync_blockdev(struct block_device *bdev, int wait) |
34 | { | |
35 | return 0; | |
36 | } | |
3f1266f1 CH |
37 | static inline void iterate_bdevs(void (*f)(struct block_device *, void *), |
38 | void *arg) | |
39 | { | |
40 | } | |
41 | static inline int emergency_thaw_bdev(struct super_block *sb) | |
42 | { | |
43 | return 0; | |
44 | } | |
3f1266f1 | 45 | #endif /* CONFIG_BLOCK */ |
7b0de42d | 46 | |
4db96b71 AM |
47 | /* |
48 | * buffer.c | |
49 | */ | |
ae259a9c CH |
50 | extern int __block_write_begin_int(struct page *page, loff_t pos, unsigned len, |
51 | get_block_t *get_block, struct iomap *iomap); | |
4db96b71 | 52 | |
07f3f05c DH |
53 | /* |
54 | * char_dev.c | |
55 | */ | |
56 | extern void __init chrdev_init(void); | |
57 | ||
9bc61ab1 DH |
58 | /* |
59 | * fs_context.c | |
60 | */ | |
ecdab150 | 61 | extern const struct fs_context_operations legacy_fs_context_ops; |
9bc61ab1 | 62 | extern int parse_monolithic_mount_data(struct fs_context *, void *); |
c9ce29ed | 63 | extern void fc_drop_locked(struct fs_context *); |
ecdab150 DH |
64 | extern void vfs_clean_context(struct fs_context *fc); |
65 | extern int finish_clean_context(struct fs_context *fc); | |
9bc61ab1 | 66 | |
0bdaea90 DH |
67 | /* |
68 | * namei.c | |
69 | */ | |
31d921c7 DH |
70 | extern int filename_lookup(int dfd, struct filename *name, unsigned flags, |
71 | struct path *path, struct path *root); | |
197df04c AV |
72 | extern int vfs_path_lookup(struct dentry *, struct vfsmount *, |
73 | const char *, unsigned int, struct path *); | |
e24ab0ef | 74 | long do_rmdir(int dfd, struct filename *name); |
da2f1362 | 75 | long do_unlinkat(int dfd, struct filename *name); |
812931d6 | 76 | int may_linkat(struct path *link); |
e886663c JA |
77 | int do_renameat2(int olddfd, struct filename *oldname, int newdfd, |
78 | struct filename *newname, unsigned int flags); | |
0bdaea90 | 79 | |
07f3f05c DH |
80 | /* |
81 | * namespace.c | |
82 | */ | |
ca71cf71 | 83 | extern struct vfsmount *lookup_mnt(const struct path *); |
19a167af | 84 | extern int finish_automount(struct vfsmount *, struct path *); |
6d59e7f5 | 85 | |
4ed5e82f | 86 | extern int sb_prepare_remount_readonly(struct super_block *); |
f03c6599 | 87 | |
6d59e7f5 | 88 | extern void __init mnt_init(void); |
3e93cd67 | 89 | |
eb04c282 | 90 | extern int __mnt_want_write_file(struct file *); |
eb04c282 | 91 | extern void __mnt_drop_write_file(struct file *); |
47cd813f | 92 | |
a07b2000 | 93 | extern void dissolve_on_fput(struct vfsmount *); |
c60166f0 CH |
94 | |
95 | int path_mount(const char *dev_name, struct path *path, | |
96 | const char *type_page, unsigned long flags, void *data_page); | |
09267def | 97 | int path_umount(struct path *path, int flags); |
c60166f0 | 98 | |
3e93cd67 AV |
99 | /* |
100 | * fs_struct.c | |
101 | */ | |
dcf787f3 | 102 | extern void chroot_fs_refs(const struct path *, const struct path *); |
864d7c4c NP |
103 | |
104 | /* | |
105 | * file_table.c | |
106 | */ | |
ea73ea72 | 107 | extern struct file *alloc_empty_file(int, const struct cred *); |
d3b1084d | 108 | extern struct file *alloc_empty_file_noaccount(int, const struct cred *); |
62c6943b AV |
109 | |
110 | /* | |
111 | * super.c | |
112 | */ | |
8d0347f6 | 113 | extern int reconfigure_super(struct fs_context *); |
eb6ef3df | 114 | extern bool trylock_super(struct super_block *sb); |
4e7b5671 | 115 | struct super_block *user_get_super(dev_t, bool excl); |
60b49885 | 116 | void put_super(struct super_block *sb); |
20284ab7 | 117 | extern bool mount_capable(struct fs_context *); |
482928d5 AV |
118 | |
119 | /* | |
120 | * open.c | |
121 | */ | |
47c805dc AV |
122 | struct open_flags { |
123 | int open_flag; | |
a218d0fd | 124 | umode_t mode; |
47c805dc AV |
125 | int acc_mode; |
126 | int intent; | |
f9652e10 | 127 | int lookup_flags; |
47c805dc | 128 | }; |
669abf4e | 129 | extern struct file *do_filp_open(int dfd, struct filename *pathname, |
f9652e10 | 130 | const struct open_flags *op); |
73d049a4 | 131 | extern struct file *do_file_open_root(struct dentry *, struct vfsmount *, |
f9652e10 | 132 | const char *, const struct open_flags *); |
35cb6d54 JA |
133 | extern struct open_how build_open_how(int flags, umode_t mode); |
134 | extern int build_open_flags(const struct open_how *how, struct open_flags *op); | |
a8dade34 | 135 | |
411d9475 | 136 | long do_sys_ftruncate(unsigned int fd, loff_t length, int small); |
1097742e | 137 | int chmod_common(const struct path *path, umode_t mode); |
55731b3c DB |
138 | int do_fchownat(int dfd, const char __user *filename, uid_t user, gid_t group, |
139 | int flag); | |
b873498f | 140 | int chown_common(const struct path *path, uid_t user, gid_t group); |
ae2bb293 | 141 | extern int vfs_open(const struct path *, struct file *); |
becfd1f3 | 142 | |
a8dade34 AV |
143 | /* |
144 | * inode.c | |
145 | */ | |
503c358c | 146 | extern long prune_icache_sb(struct super_block *sb, struct shrink_control *sc); |
4eff96dd | 147 | extern void inode_add_lru(struct inode *inode); |
f0fce87c | 148 | extern int dentry_needs_remove_privs(struct dentry *dentry); |
55fa6091 | 149 | |
a66979ab DC |
150 | /* |
151 | * fs-writeback.c | |
152 | */ | |
3942c07c | 153 | extern long get_nr_dirty_inodes(void); |
93b270f7 | 154 | extern int invalidate_inodes(struct super_block *, bool); |
a4464dbc AV |
155 | |
156 | /* | |
157 | * dcache.c | |
158 | */ | |
eed81007 | 159 | extern int d_set_mounted(struct dentry *dentry); |
503c358c | 160 | extern long prune_dcache_sb(struct super_block *sb, struct shrink_control *sc); |
ba65dc5e | 161 | extern struct dentry *d_alloc_cursor(struct dentry *); |
ab1152dd | 162 | extern struct dentry * d_alloc_pseudo(struct super_block *, const struct qstr *); |
7e5f7bb0 | 163 | extern char *simple_dname(struct dentry *, char *, int); |
9bdebc2b AV |
164 | extern void dput_to_list(struct dentry *, struct list_head *); |
165 | extern void shrink_dentry_list(struct list_head *); | |
06ae43f3 AV |
166 | |
167 | /* | |
168 | * read_write.c | |
169 | */ | |
68d70d03 | 170 | extern int rw_verify_area(int, struct file *, const loff_t *, size_t); |
599a0ac1 AV |
171 | |
172 | /* | |
173 | * pipe.c | |
174 | */ | |
175 | extern const struct file_operations pipefifo_fops; | |
8fa1f1c2 AV |
176 | |
177 | /* | |
178 | * fs_pin.c | |
179 | */ | |
fdab684d | 180 | extern void group_pin_kill(struct hlist_head *p); |
8fa1f1c2 | 181 | extern void mnt_pin_kill(struct mount *m); |
e149ed2b AV |
182 | |
183 | /* | |
184 | * fs/nsfs.c | |
185 | */ | |
be218aa2 | 186 | extern const struct dentry_operations ns_dentry_operations; |
66cf191f | 187 | |
ec1b8260 CH |
188 | /* direct-io.c: */ |
189 | int sb_init_dio_done_wq(struct super_block *sb); | |
3934e36f JA |
190 | |
191 | /* | |
192 | * fs/stat.c: | |
193 | */ | |
0018784f BM |
194 | int do_statx(int dfd, const char __user *filename, unsigned flags, |
195 | unsigned int mask, struct statx __user *buffer); |