Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | /* |
| 2 | * fs/cifs/cifsfs.h |
| 3 | * |
Steve French | 297647c | 2007-10-12 04:11:59 +0000 | [diff] [blame] | 4 | * Copyright (c) International Business Machines Corp., 2002, 2007 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 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 |
Steve French | d38d8c7 | 2007-06-28 19:44:13 +0000 | [diff] [blame] | 19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 20 | */ |
| 21 | |
| 22 | #ifndef _CIFSFS_H |
| 23 | #define _CIFSFS_H |
| 24 | |
Jeff Layton | 02323db | 2014-05-02 13:50:02 -0400 | [diff] [blame] | 25 | #include <linux/hash.h> |
| 26 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 27 | #define ROOT_I 2 |
| 28 | |
Jeff Layton | cc0bad7 | 2009-06-25 00:56:52 -0400 | [diff] [blame] | 29 | /* |
| 30 | * ino_t is 32-bits on 32-bit arch. We have to squash the 64-bit value down |
Jeff Layton | 02323db | 2014-05-02 13:50:02 -0400 | [diff] [blame] | 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. |
Jeff Layton | cc0bad7 | 2009-06-25 00:56:52 -0400 | [diff] [blame] | 33 | */ |
| 34 | static inline ino_t |
| 35 | cifs_uniqueid_to_ino_t(u64 fileid) |
| 36 | { |
Yadan Fan | 1ee9f4b | 2016-02-29 14:44:57 +0800 | [diff] [blame] | 37 | if ((sizeof(ino_t)) < (sizeof(u64))) |
| 38 | return (ino_t)hash_64(fileid, (sizeof(ino_t) * 8) - 1) + 1; |
| 39 | |
Jeff Layton | 02323db | 2014-05-02 13:50:02 -0400 | [diff] [blame] | 40 | return (ino_t)fileid; |
Yadan Fan | 1ee9f4b | 2016-02-29 14:44:57 +0800 | [diff] [blame] | 41 | |
Jeff Layton | cc0bad7 | 2009-06-25 00:56:52 -0400 | [diff] [blame] | 42 | } |
| 43 | |
Miklos Szeredi | a00be0e | 2016-09-16 12:44:21 +0200 | [diff] [blame] | 44 | static inline void cifs_set_time(struct dentry *dentry, unsigned long time) |
| 45 | { |
| 46 | dentry->d_fsdata = (void *) time; |
| 47 | } |
| 48 | |
| 49 | static inline unsigned long cifs_get_time(struct dentry *dentry) |
| 50 | { |
| 51 | return (unsigned long) dentry->d_fsdata; |
| 52 | } |
| 53 | |
Igor Mammedov | e6ab158 | 2008-01-11 01:49:48 +0000 | [diff] [blame] | 54 | extern struct file_system_type cifs_fs_type; |
Christoph Hellwig | f5e54d6 | 2006-06-28 04:26:44 -0700 | [diff] [blame] | 55 | extern const struct address_space_operations cifs_addr_ops; |
| 56 | extern const struct address_space_operations cifs_addr_ops_smallbuf; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 57 | |
Mateusz Guzik | 24261fc | 2013-03-08 16:30:03 +0100 | [diff] [blame] | 58 | /* Functions related to super block operations */ |
| 59 | extern void cifs_sb_active(struct super_block *sb); |
| 60 | extern void cifs_sb_deactive(struct super_block *sb); |
| 61 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 62 | /* Functions related to inodes */ |
Arjan van de Ven | 754661f | 2007-02-12 00:55:38 -0800 | [diff] [blame] | 63 | extern const struct inode_operations cifs_dir_inode_ops; |
Shirish Pargaonkar | 9b6763e | 2011-02-21 23:56:59 -0600 | [diff] [blame] | 64 | extern struct inode *cifs_root_iget(struct super_block *); |
Al Viro | 4acdaf2 | 2011-07-26 01:42:34 -0400 | [diff] [blame] | 65 | extern int cifs_create(struct inode *, struct dentry *, umode_t, |
Al Viro | ebfc3b4 | 2012-06-10 18:05:36 -0400 | [diff] [blame] | 66 | bool excl); |
Al Viro | d958527 | 2012-06-22 12:39:14 +0400 | [diff] [blame] | 67 | extern int cifs_atomic_open(struct inode *, struct dentry *, |
Al Viro | 30d9049 | 2012-06-22 12:40:19 +0400 | [diff] [blame] | 68 | struct file *, unsigned, umode_t, |
Al Viro | d958527 | 2012-06-22 12:39:14 +0400 | [diff] [blame] | 69 | int *); |
Steve French | 50c2f75 | 2007-07-13 00:33:32 +0000 | [diff] [blame] | 70 | extern struct dentry *cifs_lookup(struct inode *, struct dentry *, |
Al Viro | 00cd8dd | 2012-06-10 17:13:09 -0400 | [diff] [blame] | 71 | unsigned int); |
Jeff Layton | 5f0319a | 2008-09-16 14:05:16 -0400 | [diff] [blame] | 72 | extern int cifs_unlink(struct inode *dir, struct dentry *dentry); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 73 | extern int cifs_hardlink(struct dentry *, struct inode *, struct dentry *); |
Al Viro | 1a67aaf | 2011-07-26 01:52:52 -0400 | [diff] [blame] | 74 | extern int cifs_mknod(struct inode *, struct dentry *, umode_t, dev_t); |
Al Viro | 18bb1db | 2011-07-26 01:41:39 -0400 | [diff] [blame] | 75 | extern int cifs_mkdir(struct inode *, struct dentry *, umode_t); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 76 | extern int cifs_rmdir(struct inode *, struct dentry *); |
Miklos Szeredi | 7c33d59 | 2014-07-23 15:15:36 +0200 | [diff] [blame] | 77 | extern int cifs_rename2(struct inode *, struct dentry *, struct inode *, |
| 78 | struct dentry *, unsigned int); |
Pavel Shilovsky | 6feb989 | 2011-04-07 18:18:11 +0400 | [diff] [blame] | 79 | extern int cifs_revalidate_file_attr(struct file *filp); |
| 80 | extern int cifs_revalidate_dentry_attr(struct dentry *); |
Jeff Layton | abab095 | 2010-02-12 07:44:18 -0500 | [diff] [blame] | 81 | extern int cifs_revalidate_file(struct file *filp); |
Jeff Layton | df2cf17 | 2010-02-12 07:44:16 -0500 | [diff] [blame] | 82 | extern int cifs_revalidate_dentry(struct dentry *); |
Pavel Shilovsky | 6feb989 | 2011-04-07 18:18:11 +0400 | [diff] [blame] | 83 | extern int cifs_invalidate_mapping(struct inode *inode); |
Jeff Layton | e284e53 | 2014-04-30 09:31:46 -0400 | [diff] [blame] | 84 | extern int cifs_revalidate_mapping(struct inode *inode); |
Jeff Layton | 4f73c7d | 2014-04-30 09:31:47 -0400 | [diff] [blame] | 85 | extern int cifs_zap_mapping(struct inode *inode); |
David Howells | a528d35 | 2017-01-31 16:46:22 +0000 | [diff] [blame] | 86 | extern int cifs_getattr(const struct path *, struct kstat *, u32, unsigned int); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 87 | extern int cifs_setattr(struct dentry *, struct iattr *); |
| 88 | |
Arjan van de Ven | 754661f | 2007-02-12 00:55:38 -0800 | [diff] [blame] | 89 | extern const struct inode_operations cifs_file_inode_ops; |
| 90 | extern const struct inode_operations cifs_symlink_inode_ops; |
Alexey Dobriyan | 6e1d5dc | 2009-09-21 17:01:11 -0700 | [diff] [blame] | 91 | extern const struct inode_operations cifs_dfs_referral_inode_operations; |
Igor Mammedov | 6d5ae0d | 2008-01-25 03:28:31 +0000 | [diff] [blame] | 92 | |
| 93 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 94 | /* Functions related to files and directories */ |
Arjan van de Ven | 4b6f5d2 | 2006-03-28 01:56:42 -0800 | [diff] [blame] | 95 | extern const struct file_operations cifs_file_ops; |
Steve French | d38d8c7 | 2007-06-28 19:44:13 +0000 | [diff] [blame] | 96 | extern const struct file_operations cifs_file_direct_ops; /* if directio mnt */ |
Pavel Shilovsky | 8be7e6b | 2010-12-12 13:11:13 +0300 | [diff] [blame] | 97 | extern const struct file_operations cifs_file_strict_ops; /* if strictio mnt */ |
| 98 | extern const struct file_operations cifs_file_nobrl_ops; /* no brlocks */ |
| 99 | extern const struct file_operations cifs_file_direct_nobrl_ops; |
| 100 | extern const struct file_operations cifs_file_strict_nobrl_ops; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 101 | extern int cifs_open(struct inode *inode, struct file *file); |
| 102 | extern int cifs_close(struct inode *inode, struct file *file); |
| 103 | extern int cifs_closedir(struct inode *inode, struct file *file); |
Al Viro | e6a7bcb | 2014-04-02 19:53:36 -0400 | [diff] [blame] | 104 | extern ssize_t cifs_user_readv(struct kiocb *iocb, struct iov_iter *to); |
| 105 | extern ssize_t cifs_strict_readv(struct kiocb *iocb, struct iov_iter *to); |
Al Viro | 3dae875 | 2014-04-03 12:05:17 -0400 | [diff] [blame] | 106 | extern ssize_t cifs_user_writev(struct kiocb *iocb, struct iov_iter *from); |
| 107 | extern ssize_t cifs_strict_writev(struct kiocb *iocb, struct iov_iter *from); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 108 | extern int cifs_lock(struct file *, int, struct file_lock *); |
Josef Bacik | 02c24a8 | 2011-07-16 20:44:56 -0400 | [diff] [blame] | 109 | extern int cifs_fsync(struct file *, loff_t, loff_t, int); |
| 110 | extern int cifs_strict_fsync(struct file *, loff_t, loff_t, int); |
Miklos Szeredi | 75e1fcc | 2006-06-23 02:05:12 -0700 | [diff] [blame] | 111 | extern int cifs_flush(struct file *, fl_owner_t id); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 112 | extern int cifs_file_mmap(struct file * , struct vm_area_struct *); |
Pavel Shilovsky | 7a6a19b | 2010-12-14 11:29:51 +0300 | [diff] [blame] | 113 | extern int cifs_file_strict_mmap(struct file * , struct vm_area_struct *); |
Arjan van de Ven | 4b6f5d2 | 2006-03-28 01:56:42 -0800 | [diff] [blame] | 114 | extern const struct file_operations cifs_dir_ops; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 115 | extern int cifs_dir_open(struct inode *inode, struct file *file); |
Al Viro | be4ccdc | 2013-05-22 16:17:25 -0400 | [diff] [blame] | 116 | extern int cifs_readdir(struct file *file, struct dir_context *ctx); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 117 | |
| 118 | /* Functions related to dir entries */ |
Al Viro | 4fd03e8 | 2009-02-20 05:57:07 +0000 | [diff] [blame] | 119 | extern const struct dentry_operations cifs_dentry_ops; |
| 120 | extern const struct dentry_operations cifs_ci_dentry_ops; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 121 | |
David Howells | 01c64fe | 2011-01-14 18:45:47 +0000 | [diff] [blame] | 122 | #ifdef CONFIG_CIFS_DFS_UPCALL |
| 123 | extern struct vfsmount *cifs_dfs_d_automount(struct path *path); |
| 124 | #else |
| 125 | #define cifs_dfs_d_automount NULL |
| 126 | #endif |
| 127 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 128 | /* Functions related to symlinks */ |
Al Viro | fceef39 | 2015-12-29 15:58:39 -0500 | [diff] [blame] | 129 | extern const char *cifs_get_link(struct dentry *, struct inode *, |
| 130 | struct delayed_call *); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 131 | extern int cifs_symlink(struct inode *inode, struct dentry *direntry, |
| 132 | const char *symname); |
Andreas Gruenbacher | a9ae008 | 2016-04-22 12:11:38 +0200 | [diff] [blame] | 133 | |
| 134 | #ifdef CONFIG_CIFS_XATTR |
| 135 | extern const struct xattr_handler *cifs_xattr_handlers[]; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 136 | extern ssize_t cifs_listxattr(struct dentry *, char *, size_t); |
Andreas Gruenbacher | a9ae008 | 2016-04-22 12:11:38 +0200 | [diff] [blame] | 137 | #else |
| 138 | # define cifs_xattr_handlers NULL |
| 139 | # define cifs_listxattr NULL |
| 140 | #endif |
| 141 | |
Sachin Prabhu | 620d874 | 2017-02-10 16:03:51 +0530 | [diff] [blame] | 142 | extern 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 | |
Steve French | f9ddcca | 2008-05-15 05:51:55 +0000 | [diff] [blame] | 147 | extern long cifs_ioctl(struct file *filep, unsigned int cmd, unsigned long arg); |
Paul Bolle | f3a6a60 | 2011-10-12 14:14:04 +0200 | [diff] [blame] | 148 | #ifdef CONFIG_CIFS_NFSD_EXPORT |
Christoph Hellwig | 3965516 | 2007-10-21 16:42:17 -0700 | [diff] [blame] | 149 | extern const struct export_operations cifs_export_ops; |
Paul Bolle | f3a6a60 | 2011-10-12 14:14:04 +0200 | [diff] [blame] | 150 | #endif /* CONFIG_CIFS_NFSD_EXPORT */ |
Steve French | 297647c | 2007-10-12 04:11:59 +0000 | [diff] [blame] | 151 | |
Steve French | 5a4f7e8 | 2016-05-10 08:24:05 -0500 | [diff] [blame] | 152 | #define CIFS_VERSION "2.09" |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 153 | #endif /* _CIFSFS_H */ |