xen/arm: sync_bitops
[GitHub/mt8127/android_kernel_alcatel_ttab.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
eb04c282
JK
64extern int __mnt_want_write(struct vfsmount *);
65extern int __mnt_want_write_file(struct file *);
66extern void __mnt_drop_write(struct vfsmount *);
67extern void __mnt_drop_write_file(struct file *);
47cd813f 68
3e93cd67
AV
69/*
70 * fs_struct.c
71 */
72extern void chroot_fs_refs(struct path *, struct path *);
864d7c4c 73
74/*
75 * file_table.c
76 */
d996b62a
NP
77extern void file_sb_list_add(struct file *f, struct super_block *sb);
78extern void file_sb_list_del(struct file *f);
864d7c4c 79extern void mark_files_ro(struct super_block *);
e81e3f4d 80extern struct file *get_empty_filp(void);
62c6943b
AV
81
82/*
83 * super.c
84 */
85extern int do_remount_sb(struct super_block *, int, void *, int);
12ad3ab6 86extern bool grab_super_passive(struct super_block *sb);
9d412a43
AV
87extern struct dentry *mount_fs(struct file_system_type *,
88 int, const char *, void *);
cf31e70d 89extern struct super_block *user_get_super(dev_t);
482928d5
AV
90
91/*
92 * open.c
93 */
47c805dc
AV
94struct open_flags {
95 int open_flag;
a218d0fd 96 umode_t mode;
47c805dc
AV
97 int acc_mode;
98 int intent;
99};
100extern struct file *do_filp_open(int dfd, const char *pathname,
101 const struct open_flags *op, int lookup_flags);
73d049a4
AV
102extern struct file *do_file_open_root(struct dentry *, struct vfsmount *,
103 const char *, const struct open_flags *, int lookup_flags);
a8dade34 104
becfd1f3
AK
105extern long do_handle_open(int mountdirfd,
106 struct file_handle __user *ufh, int open_flag);
90ad1a8e 107extern int open_check_o_direct(struct file *f);
becfd1f3 108
a8dade34
AV
109/*
110 * inode.c
111 */
55fa6091
DC
112extern spinlock_t inode_sb_list_lock;
113
a66979ab
DC
114/*
115 * fs-writeback.c
116 */
117extern void inode_wb_list_del(struct inode *inode);
118
cffbc8aa 119extern int get_nr_dirty_inodes(void);
a4cdbd8b 120extern void evict_inodes(struct super_block *);
93b270f7 121extern int invalidate_inodes(struct super_block *, bool);
a4464dbc
AV
122
123/*
124 * dcache.c
125 */
126extern struct dentry *__d_alloc(struct super_block *, const struct qstr *);