]> git.ipfire.org Git - people/ms/linux.git/blame - fs/cifs/cifsfs.h
Merge tag 'soc-fixes-6.0-rc7' of git://git.kernel.org/pub/scm/linux/kernel/git/soc/soc
[people/ms/linux.git] / fs / cifs / cifsfs.h
CommitLineData
929be906 1/* SPDX-License-Identifier: LGPL-2.1 */
1da177e4 2/*
1da177e4 3 *
297647c2 4 * Copyright (c) International Business Machines Corp., 2002, 2007
1da177e4
LT
5 * Author(s): Steve French (sfrench@us.ibm.com)
6 *
1da177e4
LT
7 */
8
9#ifndef _CIFSFS_H
10#define _CIFSFS_H
11
02323db1
JL
12#include <linux/hash.h>
13
1da177e4
LT
14#define ROOT_I 2
15
cc0bad75
JL
16/*
17 * ino_t is 32-bits on 32-bit arch. We have to squash the 64-bit value down
02323db1
JL
18 * so that it will fit. We use hash_64 to convert the value to 31 bits, and
19 * then add 1, to ensure that we don't end up with a 0 as the value.
cc0bad75 20 */
02323db1
JL
21static inline ino_t
22cifs_uniqueid_to_ino_t(u64 fileid)
23{
1ee9f4bd
YF
24 if ((sizeof(ino_t)) < (sizeof(u64)))
25 return (ino_t)hash_64(fileid, (sizeof(ino_t) * 8) - 1) + 1;
26
02323db1 27 return (ino_t)fileid;
1ee9f4bd 28
02323db1 29}
cc0bad75 30
a00be0e3
MS
31static inline void cifs_set_time(struct dentry *dentry, unsigned long time)
32{
33 dentry->d_fsdata = (void *) time;
34}
35
36static inline unsigned long cifs_get_time(struct dentry *dentry)
37{
38 return (unsigned long) dentry->d_fsdata;
39}
40
c36ee7da 41extern struct file_system_type cifs_fs_type, smb3_fs_type;
f5e54d6e
CH
42extern const struct address_space_operations cifs_addr_ops;
43extern const struct address_space_operations cifs_addr_ops_smallbuf;
1da177e4 44
24261fc2
MG
45/* Functions related to super block operations */
46extern void cifs_sb_active(struct super_block *sb);
47extern void cifs_sb_deactive(struct super_block *sb);
48
1da177e4 49/* Functions related to inodes */
754661f1 50extern const struct inode_operations cifs_dir_inode_ops;
9b6763e0 51extern struct inode *cifs_root_iget(struct super_block *);
549c7297
CB
52extern int cifs_create(struct user_namespace *, struct inode *,
53 struct dentry *, umode_t, bool excl);
d9585277 54extern int cifs_atomic_open(struct inode *, struct dentry *,
44907d79 55 struct file *, unsigned, umode_t);
50c2f753 56extern struct dentry *cifs_lookup(struct inode *, struct dentry *,
00cd8dd3 57 unsigned int);
5f0319a7 58extern int cifs_unlink(struct inode *dir, struct dentry *dentry);
1da177e4 59extern int cifs_hardlink(struct dentry *, struct inode *, struct dentry *);
549c7297
CB
60extern int cifs_mknod(struct user_namespace *, struct inode *, struct dentry *,
61 umode_t, dev_t);
62extern int cifs_mkdir(struct user_namespace *, struct inode *, struct dentry *,
63 umode_t);
1da177e4 64extern int cifs_rmdir(struct inode *, struct dentry *);
549c7297
CB
65extern int cifs_rename2(struct user_namespace *, struct inode *,
66 struct dentry *, struct inode *, struct dentry *,
67 unsigned int);
6feb9891
PS
68extern int cifs_revalidate_file_attr(struct file *filp);
69extern int cifs_revalidate_dentry_attr(struct dentry *);
abab095d 70extern int cifs_revalidate_file(struct file *filp);
df2cf170 71extern int cifs_revalidate_dentry(struct dentry *);
6feb9891 72extern int cifs_invalidate_mapping(struct inode *inode);
e284e53f 73extern int cifs_revalidate_mapping(struct inode *inode);
4f73c7d3 74extern int cifs_zap_mapping(struct inode *inode);
549c7297
CB
75extern int cifs_getattr(struct user_namespace *, const struct path *,
76 struct kstat *, u32, unsigned int);
77extern int cifs_setattr(struct user_namespace *, struct dentry *,
78 struct iattr *);
2f3ebaba
RS
79extern int cifs_fiemap(struct inode *, struct fiemap_extent_info *, u64 start,
80 u64 len);
1da177e4 81
754661f1
AV
82extern const struct inode_operations cifs_file_inode_ops;
83extern const struct inode_operations cifs_symlink_inode_ops;
6e1d5dcc 84extern const struct inode_operations cifs_dfs_referral_inode_operations;
6d5ae0de
IM
85
86
1da177e4 87/* Functions related to files and directories */
4b6f5d20 88extern const struct file_operations cifs_file_ops;
d38d8c74 89extern const struct file_operations cifs_file_direct_ops; /* if directio mnt */
8be7e6ba
PS
90extern const struct file_operations cifs_file_strict_ops; /* if strictio mnt */
91extern const struct file_operations cifs_file_nobrl_ops; /* no brlocks */
92extern const struct file_operations cifs_file_direct_nobrl_ops;
93extern const struct file_operations cifs_file_strict_nobrl_ops;
1da177e4
LT
94extern int cifs_open(struct inode *inode, struct file *file);
95extern int cifs_close(struct inode *inode, struct file *file);
96extern int cifs_closedir(struct inode *inode, struct file *file);
e6a7bcb4 97extern ssize_t cifs_user_readv(struct kiocb *iocb, struct iov_iter *to);
6e6e2b86 98extern ssize_t cifs_direct_readv(struct kiocb *iocb, struct iov_iter *to);
e6a7bcb4 99extern ssize_t cifs_strict_readv(struct kiocb *iocb, struct iov_iter *to);
3dae8750 100extern ssize_t cifs_user_writev(struct kiocb *iocb, struct iov_iter *from);
8c5f9c1a 101extern ssize_t cifs_direct_writev(struct kiocb *iocb, struct iov_iter *from);
3dae8750 102extern ssize_t cifs_strict_writev(struct kiocb *iocb, struct iov_iter *from);
d0677992 103extern int cifs_flock(struct file *pfile, int cmd, struct file_lock *plock);
1da177e4 104extern int cifs_lock(struct file *, int, struct file_lock *);
02c24a82
JB
105extern int cifs_fsync(struct file *, loff_t, loff_t, int);
106extern int cifs_strict_fsync(struct file *, loff_t, loff_t, int);
75e1fcc0 107extern int cifs_flush(struct file *, fl_owner_t id);
1da177e4 108extern int cifs_file_mmap(struct file * , struct vm_area_struct *);
7a6a19b1 109extern int cifs_file_strict_mmap(struct file * , struct vm_area_struct *);
4b6f5d20 110extern const struct file_operations cifs_dir_ops;
1da177e4 111extern int cifs_dir_open(struct inode *inode, struct file *file);
be4ccdcc 112extern int cifs_readdir(struct file *file, struct dir_context *ctx);
1da177e4
LT
113
114/* Functions related to dir entries */
4fd03e84
AV
115extern const struct dentry_operations cifs_dentry_ops;
116extern const struct dentry_operations cifs_ci_dentry_ops;
1da177e4 117
01c64fea
DH
118#ifdef CONFIG_CIFS_DFS_UPCALL
119extern struct vfsmount *cifs_dfs_d_automount(struct path *path);
120#else
121#define cifs_dfs_d_automount NULL
122#endif
123
1da177e4 124/* Functions related to symlinks */
fceef393
AV
125extern const char *cifs_get_link(struct dentry *, struct inode *,
126 struct delayed_call *);
549c7297
CB
127extern int cifs_symlink(struct user_namespace *mnt_userns, struct inode *inode,
128 struct dentry *direntry, const char *symname);
a9ae008f
AG
129
130#ifdef CONFIG_CIFS_XATTR
131extern const struct xattr_handler *cifs_xattr_handlers[];
1da177e4 132extern ssize_t cifs_listxattr(struct dentry *, char *, size_t);
a9ae008f
AG
133#else
134# define cifs_xattr_handlers NULL
135# define cifs_listxattr NULL
136#endif
137
620d8745
SP
138extern ssize_t cifs_file_copychunk_range(unsigned int xid,
139 struct file *src_file, loff_t off,
140 struct file *dst_file, loff_t destoff,
141 size_t len, unsigned int flags);
142
f9ddcca4 143extern long cifs_ioctl(struct file *filep, unsigned int cmd, unsigned long arg);
8bd0d701
RS
144extern void cifs_setsize(struct inode *inode, loff_t offset);
145extern int cifs_truncate_page(struct address_space *mapping, loff_t from);
146
24e0a1ef
RS
147struct smb3_fs_context;
148extern struct dentry *cifs_smb3_do_mount(struct file_system_type *fs_type,
149 int flags, struct smb3_fs_context *ctx);
150
f3a6a60e 151#ifdef CONFIG_CIFS_NFSD_EXPORT
39655164 152extern const struct export_operations cifs_export_ops;
f3a6a60e 153#endif /* CONFIG_CIFS_NFSD_EXPORT */
297647c2 154
096c956b 155/* when changing internal version - update following two lines at same time */
8af8aed9
SF
156#define SMB3_PRODUCT_BUILD 39
157#define CIFS_VERSION "2.39"
1da177e4 158#endif /* _CIFSFS_H */