138c8a9a5SSteve French /* SPDX-License-Identifier: LGPL-2.1 */
238c8a9a5SSteve French /*
338c8a9a5SSteve French *
438c8a9a5SSteve French * Copyright (c) International Business Machines Corp., 2002, 2007
538c8a9a5SSteve French * Author(s): Steve French (sfrench@us.ibm.com)
638c8a9a5SSteve French *
738c8a9a5SSteve French */
838c8a9a5SSteve French
938c8a9a5SSteve French #ifndef _CIFSFS_H
1038c8a9a5SSteve French #define _CIFSFS_H
1138c8a9a5SSteve French
1238c8a9a5SSteve French #include <linux/hash.h>
1338c8a9a5SSteve French
1438c8a9a5SSteve French #define ROOT_I 2
1538c8a9a5SSteve French
1638c8a9a5SSteve French /*
1738c8a9a5SSteve French * ino_t is 32-bits on 32-bit arch. We have to squash the 64-bit value down
1838c8a9a5SSteve French * so that it will fit. We use hash_64 to convert the value to 31 bits, and
1938c8a9a5SSteve French * then add 1, to ensure that we don't end up with a 0 as the value.
2038c8a9a5SSteve French */
2138c8a9a5SSteve French static inline ino_t
cifs_uniqueid_to_ino_t(u64 fileid)2238c8a9a5SSteve French cifs_uniqueid_to_ino_t(u64 fileid)
2338c8a9a5SSteve French {
2438c8a9a5SSteve French if ((sizeof(ino_t)) < (sizeof(u64)))
2538c8a9a5SSteve French return (ino_t)hash_64(fileid, (sizeof(ino_t) * 8) - 1) + 1;
2638c8a9a5SSteve French
2738c8a9a5SSteve French return (ino_t)fileid;
2838c8a9a5SSteve French
2938c8a9a5SSteve French }
3038c8a9a5SSteve French
cifs_set_time(struct dentry * dentry,unsigned long time)3138c8a9a5SSteve French static inline void cifs_set_time(struct dentry *dentry, unsigned long time)
3238c8a9a5SSteve French {
3338c8a9a5SSteve French dentry->d_fsdata = (void *) time;
3438c8a9a5SSteve French }
3538c8a9a5SSteve French
cifs_get_time(struct dentry * dentry)3638c8a9a5SSteve French static inline unsigned long cifs_get_time(struct dentry *dentry)
3738c8a9a5SSteve French {
3838c8a9a5SSteve French return (unsigned long) dentry->d_fsdata;
3938c8a9a5SSteve French }
4038c8a9a5SSteve French
4138c8a9a5SSteve French extern struct file_system_type cifs_fs_type, smb3_fs_type;
4238c8a9a5SSteve French extern const struct address_space_operations cifs_addr_ops;
4338c8a9a5SSteve French extern const struct address_space_operations cifs_addr_ops_smallbuf;
4438c8a9a5SSteve French
4538c8a9a5SSteve French /* Functions related to super block operations */
4638c8a9a5SSteve French extern void cifs_sb_active(struct super_block *sb);
4738c8a9a5SSteve French extern void cifs_sb_deactive(struct super_block *sb);
4838c8a9a5SSteve French
4938c8a9a5SSteve French /* Functions related to inodes */
5038c8a9a5SSteve French extern const struct inode_operations cifs_dir_inode_ops;
5138c8a9a5SSteve French extern struct inode *cifs_root_iget(struct super_block *);
5238c8a9a5SSteve French extern int cifs_create(struct mnt_idmap *, struct inode *,
5338c8a9a5SSteve French struct dentry *, umode_t, bool excl);
5438c8a9a5SSteve French extern int cifs_atomic_open(struct inode *, struct dentry *,
5538c8a9a5SSteve French struct file *, unsigned, umode_t);
5638c8a9a5SSteve French extern struct dentry *cifs_lookup(struct inode *, struct dentry *,
5738c8a9a5SSteve French unsigned int);
5838c8a9a5SSteve French extern int cifs_unlink(struct inode *dir, struct dentry *dentry);
5938c8a9a5SSteve French extern int cifs_hardlink(struct dentry *, struct inode *, struct dentry *);
6038c8a9a5SSteve French extern int cifs_mknod(struct mnt_idmap *, struct inode *, struct dentry *,
6138c8a9a5SSteve French umode_t, dev_t);
6238c8a9a5SSteve French extern int cifs_mkdir(struct mnt_idmap *, struct inode *, struct dentry *,
6338c8a9a5SSteve French umode_t);
6438c8a9a5SSteve French extern int cifs_rmdir(struct inode *, struct dentry *);
6538c8a9a5SSteve French extern int cifs_rename2(struct mnt_idmap *, struct inode *,
6638c8a9a5SSteve French struct dentry *, struct inode *, struct dentry *,
6738c8a9a5SSteve French unsigned int);
6838c8a9a5SSteve French extern int cifs_revalidate_file_attr(struct file *filp);
6938c8a9a5SSteve French extern int cifs_revalidate_dentry_attr(struct dentry *);
7038c8a9a5SSteve French extern int cifs_revalidate_file(struct file *filp);
7138c8a9a5SSteve French extern int cifs_revalidate_dentry(struct dentry *);
7238c8a9a5SSteve French extern int cifs_invalidate_mapping(struct inode *inode);
7338c8a9a5SSteve French extern int cifs_revalidate_mapping(struct inode *inode);
7438c8a9a5SSteve French extern int cifs_zap_mapping(struct inode *inode);
7538c8a9a5SSteve French extern int cifs_getattr(struct mnt_idmap *, const struct path *,
7638c8a9a5SSteve French struct kstat *, u32, unsigned int);
7738c8a9a5SSteve French extern int cifs_setattr(struct mnt_idmap *, struct dentry *,
7838c8a9a5SSteve French struct iattr *);
7938c8a9a5SSteve French extern int cifs_fiemap(struct inode *, struct fiemap_extent_info *, u64 start,
8038c8a9a5SSteve French u64 len);
8138c8a9a5SSteve French
8238c8a9a5SSteve French extern const struct inode_operations cifs_file_inode_ops;
8338c8a9a5SSteve French extern const struct inode_operations cifs_symlink_inode_ops;
840a049935SPaulo Alcantara extern const struct inode_operations cifs_namespace_inode_operations;
8538c8a9a5SSteve French
8638c8a9a5SSteve French
8738c8a9a5SSteve French /* Functions related to files and directories */
8838c8a9a5SSteve French extern const struct file_operations cifs_file_ops;
8938c8a9a5SSteve French extern const struct file_operations cifs_file_direct_ops; /* if directio mnt */
9038c8a9a5SSteve French extern const struct file_operations cifs_file_strict_ops; /* if strictio mnt */
9138c8a9a5SSteve French extern const struct file_operations cifs_file_nobrl_ops; /* no brlocks */
9238c8a9a5SSteve French extern const struct file_operations cifs_file_direct_nobrl_ops;
9338c8a9a5SSteve French extern const struct file_operations cifs_file_strict_nobrl_ops;
9438c8a9a5SSteve French extern int cifs_open(struct inode *inode, struct file *file);
9538c8a9a5SSteve French extern int cifs_close(struct inode *inode, struct file *file);
9638c8a9a5SSteve French extern int cifs_closedir(struct inode *inode, struct file *file);
9738c8a9a5SSteve French extern ssize_t cifs_user_readv(struct kiocb *iocb, struct iov_iter *to);
9838c8a9a5SSteve French extern ssize_t cifs_direct_readv(struct kiocb *iocb, struct iov_iter *to);
9938c8a9a5SSteve French extern ssize_t cifs_strict_readv(struct kiocb *iocb, struct iov_iter *to);
10038c8a9a5SSteve French extern ssize_t cifs_user_writev(struct kiocb *iocb, struct iov_iter *from);
10138c8a9a5SSteve French extern ssize_t cifs_direct_writev(struct kiocb *iocb, struct iov_iter *from);
10238c8a9a5SSteve French extern ssize_t cifs_strict_writev(struct kiocb *iocb, struct iov_iter *from);
10338c8a9a5SSteve French extern int cifs_flock(struct file *pfile, int cmd, struct file_lock *plock);
10438c8a9a5SSteve French extern int cifs_lock(struct file *, int, struct file_lock *);
10538c8a9a5SSteve French extern int cifs_fsync(struct file *, loff_t, loff_t, int);
10638c8a9a5SSteve French extern int cifs_strict_fsync(struct file *, loff_t, loff_t, int);
10738c8a9a5SSteve French extern int cifs_flush(struct file *, fl_owner_t id);
10838c8a9a5SSteve French extern int cifs_file_mmap(struct file *file, struct vm_area_struct *vma);
10938c8a9a5SSteve French extern int cifs_file_strict_mmap(struct file *file, struct vm_area_struct *vma);
11038c8a9a5SSteve French extern const struct file_operations cifs_dir_ops;
11138c8a9a5SSteve French extern int cifs_dir_open(struct inode *inode, struct file *file);
11238c8a9a5SSteve French extern int cifs_readdir(struct file *file, struct dir_context *ctx);
11338c8a9a5SSteve French extern void cifs_pages_written_back(struct inode *inode, loff_t start, unsigned int len);
11438c8a9a5SSteve French extern void cifs_pages_write_failed(struct inode *inode, loff_t start, unsigned int len);
11538c8a9a5SSteve French extern void cifs_pages_write_redirty(struct inode *inode, loff_t start, unsigned int len);
11638c8a9a5SSteve French
11738c8a9a5SSteve French /* Functions related to dir entries */
11838c8a9a5SSteve French extern const struct dentry_operations cifs_dentry_ops;
11938c8a9a5SSteve French extern const struct dentry_operations cifs_ci_dentry_ops;
12038c8a9a5SSteve French
1210a049935SPaulo Alcantara extern struct vfsmount *cifs_d_automount(struct path *path);
12238c8a9a5SSteve French
12338c8a9a5SSteve French /* Functions related to symlinks */
12438c8a9a5SSteve French extern const char *cifs_get_link(struct dentry *, struct inode *,
12538c8a9a5SSteve French struct delayed_call *);
12638c8a9a5SSteve French extern int cifs_symlink(struct mnt_idmap *idmap, struct inode *inode,
12738c8a9a5SSteve French struct dentry *direntry, const char *symname);
12838c8a9a5SSteve French
12938c8a9a5SSteve French #ifdef CONFIG_CIFS_XATTR
13038c8a9a5SSteve French extern const struct xattr_handler *cifs_xattr_handlers[];
13138c8a9a5SSteve French extern ssize_t cifs_listxattr(struct dentry *, char *, size_t);
13238c8a9a5SSteve French #else
13338c8a9a5SSteve French # define cifs_xattr_handlers NULL
13438c8a9a5SSteve French # define cifs_listxattr NULL
13538c8a9a5SSteve French #endif
13638c8a9a5SSteve French
13738c8a9a5SSteve French extern ssize_t cifs_file_copychunk_range(unsigned int xid,
13838c8a9a5SSteve French struct file *src_file, loff_t off,
13938c8a9a5SSteve French struct file *dst_file, loff_t destoff,
14038c8a9a5SSteve French size_t len, unsigned int flags);
14138c8a9a5SSteve French
14238c8a9a5SSteve French extern long cifs_ioctl(struct file *filep, unsigned int cmd, unsigned long arg);
14338c8a9a5SSteve French extern void cifs_setsize(struct inode *inode, loff_t offset);
14438c8a9a5SSteve French extern int cifs_truncate_page(struct address_space *mapping, loff_t from);
14538c8a9a5SSteve French
14638c8a9a5SSteve French struct smb3_fs_context;
14738c8a9a5SSteve French extern struct dentry *cifs_smb3_do_mount(struct file_system_type *fs_type,
14838c8a9a5SSteve French int flags, struct smb3_fs_context *ctx);
14938c8a9a5SSteve French
15038c8a9a5SSteve French #ifdef CONFIG_CIFS_NFSD_EXPORT
15138c8a9a5SSteve French extern const struct export_operations cifs_export_ops;
15238c8a9a5SSteve French #endif /* CONFIG_CIFS_NFSD_EXPORT */
15338c8a9a5SSteve French
15438c8a9a5SSteve French /* when changing internal version - update following two lines at same time */
155*30bded94SSteve French #define SMB3_PRODUCT_BUILD 45
156*30bded94SSteve French #define CIFS_VERSION "2.45"
15738c8a9a5SSteve French #endif /* _CIFSFS_H */
158