]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/blame - fs/cifs/cifsfs.h
Merge branches 'acpi-soc', 'acpi-wdat' and 'acpi-cppc'
[mirror_ubuntu-artful-kernel.git] / fs / cifs / cifsfs.h
CommitLineData
1da177e4
LT
1/*
2 * fs/cifs/cifsfs.h
3 *
297647c2 4 * Copyright (c) International Business Machines Corp., 2002, 2007
1da177e4
LT
5 * Author(s): Steve French (sfrench@us.ibm.com)
6 *
7 * This library is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU Lesser General Public License as published
9 * by the Free Software Foundation; either version 2.1 of the License, or
10 * (at your option) any later version.
11 *
12 * This library is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See
15 * the GNU Lesser General Public License for more details.
16 *
17 * You should have received a copy of the GNU Lesser General Public License
18 * along with this library; if not, write to the Free Software
d38d8c74 19 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
1da177e4
LT
20 */
21
22#ifndef _CIFSFS_H
23#define _CIFSFS_H
24
02323db1
JL
25#include <linux/hash.h>
26
1da177e4
LT
27#define ROOT_I 2
28
cc0bad75
JL
29/*
30 * ino_t is 32-bits on 32-bit arch. We have to squash the 64-bit value down
02323db1
JL
31 * so that it will fit. We use hash_64 to convert the value to 31 bits, and
32 * then add 1, to ensure that we don't end up with a 0 as the value.
cc0bad75 33 */
02323db1
JL
34static inline ino_t
35cifs_uniqueid_to_ino_t(u64 fileid)
36{
1ee9f4bd
YF
37 if ((sizeof(ino_t)) < (sizeof(u64)))
38 return (ino_t)hash_64(fileid, (sizeof(ino_t) * 8) - 1) + 1;
39
02323db1 40 return (ino_t)fileid;
1ee9f4bd 41
02323db1 42}
cc0bad75 43
a00be0e3
MS
44static inline void cifs_set_time(struct dentry *dentry, unsigned long time)
45{
46 dentry->d_fsdata = (void *) time;
47}
48
49static inline unsigned long cifs_get_time(struct dentry *dentry)
50{
51 return (unsigned long) dentry->d_fsdata;
52}
53
e6ab1582 54extern struct file_system_type cifs_fs_type;
f5e54d6e
CH
55extern const struct address_space_operations cifs_addr_ops;
56extern const struct address_space_operations cifs_addr_ops_smallbuf;
1da177e4 57
24261fc2
MG
58/* Functions related to super block operations */
59extern void cifs_sb_active(struct super_block *sb);
60extern void cifs_sb_deactive(struct super_block *sb);
61
1da177e4 62/* Functions related to inodes */
754661f1 63extern const struct inode_operations cifs_dir_inode_ops;
9b6763e0 64extern struct inode *cifs_root_iget(struct super_block *);
4acdaf27 65extern int cifs_create(struct inode *, struct dentry *, umode_t,
ebfc3b49 66 bool excl);
d9585277 67extern int cifs_atomic_open(struct inode *, struct dentry *,
30d90494 68 struct file *, unsigned, umode_t,
d9585277 69 int *);
50c2f753 70extern struct dentry *cifs_lookup(struct inode *, struct dentry *,
00cd8dd3 71 unsigned int);
5f0319a7 72extern int cifs_unlink(struct inode *dir, struct dentry *dentry);
1da177e4 73extern int cifs_hardlink(struct dentry *, struct inode *, struct dentry *);
1a67aafb 74extern int cifs_mknod(struct inode *, struct dentry *, umode_t, dev_t);
18bb1db3 75extern int cifs_mkdir(struct inode *, struct dentry *, umode_t);
1da177e4 76extern int cifs_rmdir(struct inode *, struct dentry *);
7c33d597
MS
77extern int cifs_rename2(struct inode *, struct dentry *, struct inode *,
78 struct dentry *, unsigned int);
6feb9891
PS
79extern int cifs_revalidate_file_attr(struct file *filp);
80extern int cifs_revalidate_dentry_attr(struct dentry *);
abab095d 81extern int cifs_revalidate_file(struct file *filp);
df2cf170 82extern int cifs_revalidate_dentry(struct dentry *);
6feb9891 83extern int cifs_invalidate_mapping(struct inode *inode);
e284e53f 84extern int cifs_revalidate_mapping(struct inode *inode);
4f73c7d3 85extern int cifs_zap_mapping(struct inode *inode);
a528d35e 86extern int cifs_getattr(const struct path *, struct kstat *, u32, unsigned int);
1da177e4
LT
87extern int cifs_setattr(struct dentry *, struct iattr *);
88
754661f1
AV
89extern const struct inode_operations cifs_file_inode_ops;
90extern const struct inode_operations cifs_symlink_inode_ops;
6e1d5dcc 91extern const struct inode_operations cifs_dfs_referral_inode_operations;
6d5ae0de
IM
92
93
1da177e4 94/* Functions related to files and directories */
4b6f5d20 95extern const struct file_operations cifs_file_ops;
d38d8c74 96extern const struct file_operations cifs_file_direct_ops; /* if directio mnt */
8be7e6ba
PS
97extern const struct file_operations cifs_file_strict_ops; /* if strictio mnt */
98extern const struct file_operations cifs_file_nobrl_ops; /* no brlocks */
99extern const struct file_operations cifs_file_direct_nobrl_ops;
100extern const struct file_operations cifs_file_strict_nobrl_ops;
1da177e4
LT
101extern int cifs_open(struct inode *inode, struct file *file);
102extern int cifs_close(struct inode *inode, struct file *file);
103extern int cifs_closedir(struct inode *inode, struct file *file);
e6a7bcb4
AV
104extern ssize_t cifs_user_readv(struct kiocb *iocb, struct iov_iter *to);
105extern ssize_t cifs_strict_readv(struct kiocb *iocb, struct iov_iter *to);
3dae8750
AV
106extern ssize_t cifs_user_writev(struct kiocb *iocb, struct iov_iter *from);
107extern ssize_t cifs_strict_writev(struct kiocb *iocb, struct iov_iter *from);
1da177e4 108extern int cifs_lock(struct file *, int, struct file_lock *);
02c24a82
JB
109extern int cifs_fsync(struct file *, loff_t, loff_t, int);
110extern int cifs_strict_fsync(struct file *, loff_t, loff_t, int);
75e1fcc0 111extern int cifs_flush(struct file *, fl_owner_t id);
1da177e4 112extern int cifs_file_mmap(struct file * , struct vm_area_struct *);
7a6a19b1 113extern int cifs_file_strict_mmap(struct file * , struct vm_area_struct *);
4b6f5d20 114extern const struct file_operations cifs_dir_ops;
1da177e4 115extern int cifs_dir_open(struct inode *inode, struct file *file);
be4ccdcc 116extern int cifs_readdir(struct file *file, struct dir_context *ctx);
1da177e4
LT
117
118/* Functions related to dir entries */
4fd03e84
AV
119extern const struct dentry_operations cifs_dentry_ops;
120extern const struct dentry_operations cifs_ci_dentry_ops;
1da177e4 121
01c64fea
DH
122#ifdef CONFIG_CIFS_DFS_UPCALL
123extern struct vfsmount *cifs_dfs_d_automount(struct path *path);
124#else
125#define cifs_dfs_d_automount NULL
126#endif
127
1da177e4 128/* Functions related to symlinks */
fceef393
AV
129extern const char *cifs_get_link(struct dentry *, struct inode *,
130 struct delayed_call *);
1da177e4
LT
131extern int cifs_symlink(struct inode *inode, struct dentry *direntry,
132 const char *symname);
a9ae008f
AG
133
134#ifdef CONFIG_CIFS_XATTR
135extern const struct xattr_handler *cifs_xattr_handlers[];
1da177e4 136extern ssize_t cifs_listxattr(struct dentry *, char *, size_t);
a9ae008f
AG
137#else
138# define cifs_xattr_handlers NULL
139# define cifs_listxattr NULL
140#endif
141
620d8745
SP
142extern ssize_t cifs_file_copychunk_range(unsigned int xid,
143 struct file *src_file, loff_t off,
144 struct file *dst_file, loff_t destoff,
145 size_t len, unsigned int flags);
146
f9ddcca4 147extern long cifs_ioctl(struct file *filep, unsigned int cmd, unsigned long arg);
f3a6a60e 148#ifdef CONFIG_CIFS_NFSD_EXPORT
39655164 149extern const struct export_operations cifs_export_ops;
f3a6a60e 150#endif /* CONFIG_CIFS_NFSD_EXPORT */
297647c2 151
5a4f7e8e 152#define CIFS_VERSION "2.09"
1da177e4 153#endif /* _CIFSFS_H */