]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/blame - fs/internal.h
Add missing unlocks to error paths of mountpoint_last.
[mirror_ubuntu-artful-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);
197df04c
AV
48extern int user_path_mountpoint_at(int, const char __user *, unsigned int, struct path *);
49extern int vfs_path_lookup(struct dentry *, struct vfsmount *,
50 const char *, unsigned int, struct path *);
0bdaea90 51
07f3f05c
DH
52/*
53 * namespace.c
54 */
55extern int copy_mount_options(const void __user *, unsigned long *);
eca6f534 56extern int copy_mount_string(const void __user *, char **);
6d59e7f5 57
0f60f240 58extern struct vfsmount *lookup_mnt(struct path *);
19a167af 59extern int finish_automount(struct vfsmount *, struct path *);
6d59e7f5 60
4ed5e82f 61extern int sb_prepare_remount_readonly(struct super_block *);
f03c6599 62
6d59e7f5 63extern void __init mnt_init(void);
3e93cd67 64
eea62f83 65extern struct lglock vfsmount_lock;
99b7db7b 66
eb04c282
JK
67extern int __mnt_want_write(struct vfsmount *);
68extern int __mnt_want_write_file(struct file *);
69extern void __mnt_drop_write(struct vfsmount *);
70extern void __mnt_drop_write_file(struct file *);
47cd813f 71
3e93cd67
AV
72/*
73 * fs_struct.c
74 */
dcf787f3 75extern void chroot_fs_refs(const struct path *, const struct path *);
864d7c4c 76
77/*
78 * file_table.c
79 */
d996b62a
NP
80extern void file_sb_list_add(struct file *f, struct super_block *sb);
81extern void file_sb_list_del(struct file *f);
864d7c4c 82extern void mark_files_ro(struct super_block *);
e81e3f4d 83extern struct file *get_empty_filp(void);
62c6943b
AV
84
85/*
86 * super.c
87 */
88extern int do_remount_sb(struct super_block *, int, void *, int);
12ad3ab6 89extern bool grab_super_passive(struct super_block *sb);
9d412a43
AV
90extern struct dentry *mount_fs(struct file_system_type *,
91 int, const char *, void *);
cf31e70d 92extern struct super_block *user_get_super(dev_t);
482928d5
AV
93
94/*
95 * open.c
96 */
47c805dc
AV
97struct open_flags {
98 int open_flag;
a218d0fd 99 umode_t mode;
47c805dc
AV
100 int acc_mode;
101 int intent;
f9652e10 102 int lookup_flags;
47c805dc 103};
669abf4e 104extern struct file *do_filp_open(int dfd, struct filename *pathname,
f9652e10 105 const struct open_flags *op);
73d049a4 106extern struct file *do_file_open_root(struct dentry *, struct vfsmount *,
f9652e10 107 const char *, const struct open_flags *);
a8dade34 108
becfd1f3
AK
109extern long do_handle_open(int mountdirfd,
110 struct file_handle __user *ufh, int open_flag);
90ad1a8e 111extern int open_check_o_direct(struct file *f);
becfd1f3 112
a8dade34
AV
113/*
114 * inode.c
115 */
55fa6091 116extern spinlock_t inode_sb_list_lock;
4eff96dd 117extern void inode_add_lru(struct inode *inode);
55fa6091 118
a66979ab
DC
119/*
120 * fs-writeback.c
121 */
122extern void inode_wb_list_del(struct inode *inode);
123
cffbc8aa 124extern int get_nr_dirty_inodes(void);
a4cdbd8b 125extern void evict_inodes(struct super_block *);
93b270f7 126extern int invalidate_inodes(struct super_block *, bool);
a4464dbc
AV
127
128/*
129 * dcache.c
130 */
131extern struct dentry *__d_alloc(struct super_block *, const struct qstr *);
eed81007 132extern int d_set_mounted(struct dentry *dentry);
06ae43f3
AV
133
134/*
135 * read_write.c
136 */
137extern ssize_t __kernel_write(struct file *, const char *, size_t, loff_t *);
68d70d03 138extern int rw_verify_area(int, struct file *, const loff_t *, size_t);
599a0ac1 139
7995bd28
AV
140/*
141 * splice.c
142 */
143extern long do_splice_direct(struct file *in, loff_t *ppos, struct file *out,
144 loff_t *opos, size_t len, unsigned int flags);
145
599a0ac1
AV
146/*
147 * pipe.c
148 */
149extern const struct file_operations pipefifo_fops;