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 | */ |
Jeff Layton | 02323db | 2014-05-02 13:50:02 -0400 | [diff] [blame] | 34 | #if BITS_PER_LONG == 64 |
Jeff Layton | cc0bad7 | 2009-06-25 00:56:52 -0400 | [diff] [blame] | 35 | static inline ino_t |
| 36 | cifs_uniqueid_to_ino_t(u64 fileid) |
| 37 | { |
Jeff Layton | 02323db | 2014-05-02 13:50:02 -0400 | [diff] [blame] | 38 | return (ino_t)fileid; |
Jeff Layton | cc0bad7 | 2009-06-25 00:56:52 -0400 | [diff] [blame] | 39 | } |
Jeff Layton | 02323db | 2014-05-02 13:50:02 -0400 | [diff] [blame] | 40 | #else |
| 41 | static inline ino_t |
| 42 | cifs_uniqueid_to_ino_t(u64 fileid) |
| 43 | { |
| 44 | return (ino_t)hash_64(fileid, (sizeof(ino_t) * 8) - 1) + 1; |
| 45 | } |
| 46 | #endif |
Jeff Layton | cc0bad7 | 2009-06-25 00:56:52 -0400 | [diff] [blame] | 47 | |
Igor Mammedov | e6ab158 | 2008-01-11 01:49:48 +0000 | [diff] [blame] | 48 | extern struct file_system_type cifs_fs_type; |
Christoph Hellwig | f5e54d6 | 2006-06-28 04:26:44 -0700 | [diff] [blame] | 49 | extern const struct address_space_operations cifs_addr_ops; |
| 50 | extern const struct address_space_operations cifs_addr_ops_smallbuf; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 51 | |
Mateusz Guzik | 24261fc | 2013-03-08 16:30:03 +0100 | [diff] [blame] | 52 | /* Functions related to super block operations */ |
| 53 | extern void cifs_sb_active(struct super_block *sb); |
| 54 | extern void cifs_sb_deactive(struct super_block *sb); |
| 55 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 56 | /* Functions related to inodes */ |
Arjan van de Ven | 754661f | 2007-02-12 00:55:38 -0800 | [diff] [blame] | 57 | extern const struct inode_operations cifs_dir_inode_ops; |
Shirish Pargaonkar | 9b6763e | 2011-02-21 23:56:59 -0600 | [diff] [blame] | 58 | extern struct inode *cifs_root_iget(struct super_block *); |
Al Viro | 4acdaf2 | 2011-07-26 01:42:34 -0400 | [diff] [blame] | 59 | extern int cifs_create(struct inode *, struct dentry *, umode_t, |
Al Viro | ebfc3b4 | 2012-06-10 18:05:36 -0400 | [diff] [blame] | 60 | bool excl); |
Al Viro | d958527 | 2012-06-22 12:39:14 +0400 | [diff] [blame] | 61 | extern int cifs_atomic_open(struct inode *, struct dentry *, |
Al Viro | 30d9049 | 2012-06-22 12:40:19 +0400 | [diff] [blame] | 62 | struct file *, unsigned, umode_t, |
Al Viro | d958527 | 2012-06-22 12:39:14 +0400 | [diff] [blame] | 63 | int *); |
Steve French | 50c2f75 | 2007-07-13 00:33:32 +0000 | [diff] [blame] | 64 | extern struct dentry *cifs_lookup(struct inode *, struct dentry *, |
Al Viro | 00cd8dd | 2012-06-10 17:13:09 -0400 | [diff] [blame] | 65 | unsigned int); |
Jeff Layton | 5f0319a | 2008-09-16 14:05:16 -0400 | [diff] [blame] | 66 | extern int cifs_unlink(struct inode *dir, struct dentry *dentry); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 67 | extern int cifs_hardlink(struct dentry *, struct inode *, struct dentry *); |
Al Viro | 1a67aaf | 2011-07-26 01:52:52 -0400 | [diff] [blame] | 68 | extern int cifs_mknod(struct inode *, struct dentry *, umode_t, dev_t); |
Al Viro | 18bb1db | 2011-07-26 01:41:39 -0400 | [diff] [blame] | 69 | extern int cifs_mkdir(struct inode *, struct dentry *, umode_t); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 70 | extern int cifs_rmdir(struct inode *, struct dentry *); |
| 71 | extern int cifs_rename(struct inode *, struct dentry *, struct inode *, |
| 72 | struct dentry *); |
Pavel Shilovsky | 6feb989 | 2011-04-07 18:18:11 +0400 | [diff] [blame] | 73 | extern int cifs_revalidate_file_attr(struct file *filp); |
| 74 | extern int cifs_revalidate_dentry_attr(struct dentry *); |
Jeff Layton | abab095 | 2010-02-12 07:44:18 -0500 | [diff] [blame] | 75 | extern int cifs_revalidate_file(struct file *filp); |
Jeff Layton | df2cf17 | 2010-02-12 07:44:16 -0500 | [diff] [blame] | 76 | extern int cifs_revalidate_dentry(struct dentry *); |
Pavel Shilovsky | 6feb989 | 2011-04-07 18:18:11 +0400 | [diff] [blame] | 77 | extern int cifs_invalidate_mapping(struct inode *inode); |
Jeff Layton | e284e53 | 2014-04-30 09:31:46 -0400 | [diff] [blame] | 78 | extern int cifs_revalidate_mapping(struct inode *inode); |
Jeff Layton | 4f73c7d | 2014-04-30 09:31:47 -0400 | [diff] [blame^] | 79 | extern int cifs_zap_mapping(struct inode *inode); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 80 | extern int cifs_getattr(struct vfsmount *, struct dentry *, struct kstat *); |
| 81 | extern int cifs_setattr(struct dentry *, struct iattr *); |
| 82 | |
Arjan van de Ven | 754661f | 2007-02-12 00:55:38 -0800 | [diff] [blame] | 83 | extern const struct inode_operations cifs_file_inode_ops; |
| 84 | extern const struct inode_operations cifs_symlink_inode_ops; |
Alexey Dobriyan | 6e1d5dc | 2009-09-21 17:01:11 -0700 | [diff] [blame] | 85 | extern const struct inode_operations cifs_dfs_referral_inode_operations; |
Igor Mammedov | 6d5ae0d | 2008-01-25 03:28:31 +0000 | [diff] [blame] | 86 | |
| 87 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 88 | /* Functions related to files and directories */ |
Arjan van de Ven | 4b6f5d2 | 2006-03-28 01:56:42 -0800 | [diff] [blame] | 89 | extern const struct file_operations cifs_file_ops; |
Steve French | d38d8c7 | 2007-06-28 19:44:13 +0000 | [diff] [blame] | 90 | extern const struct file_operations cifs_file_direct_ops; /* if directio mnt */ |
Pavel Shilovsky | 8be7e6b | 2010-12-12 13:11:13 +0300 | [diff] [blame] | 91 | extern const struct file_operations cifs_file_strict_ops; /* if strictio mnt */ |
| 92 | extern const struct file_operations cifs_file_nobrl_ops; /* no brlocks */ |
| 93 | extern const struct file_operations cifs_file_direct_nobrl_ops; |
| 94 | extern const struct file_operations cifs_file_strict_nobrl_ops; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 95 | extern int cifs_open(struct inode *inode, struct file *file); |
| 96 | extern int cifs_close(struct inode *inode, struct file *file); |
| 97 | extern int cifs_closedir(struct inode *inode, struct file *file); |
Pavel Shilovsky | 0b81c1c | 2011-03-10 10:11:05 +0300 | [diff] [blame] | 98 | extern ssize_t cifs_user_readv(struct kiocb *iocb, const struct iovec *iov, |
| 99 | unsigned long nr_segs, loff_t pos); |
Pavel Shilovsky | a70307e | 2010-12-14 11:50:41 +0300 | [diff] [blame] | 100 | extern ssize_t cifs_strict_readv(struct kiocb *iocb, const struct iovec *iov, |
| 101 | unsigned long nr_segs, loff_t pos); |
Pavel Shilovsky | 0b81c1c | 2011-03-10 10:11:05 +0300 | [diff] [blame] | 102 | extern ssize_t cifs_user_writev(struct kiocb *iocb, const struct iovec *iov, |
| 103 | unsigned long nr_segs, loff_t pos); |
Pavel Shilovsky | 72432ff | 2011-01-24 14:16:35 -0500 | [diff] [blame] | 104 | extern ssize_t cifs_strict_writev(struct kiocb *iocb, const struct iovec *iov, |
| 105 | unsigned long nr_segs, loff_t pos); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 106 | extern int cifs_lock(struct file *, int, struct file_lock *); |
Josef Bacik | 02c24a8 | 2011-07-16 20:44:56 -0400 | [diff] [blame] | 107 | extern int cifs_fsync(struct file *, loff_t, loff_t, int); |
| 108 | extern int cifs_strict_fsync(struct file *, loff_t, loff_t, int); |
Miklos Szeredi | 75e1fcc | 2006-06-23 02:05:12 -0700 | [diff] [blame] | 109 | extern int cifs_flush(struct file *, fl_owner_t id); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 110 | extern int cifs_file_mmap(struct file * , struct vm_area_struct *); |
Pavel Shilovsky | 7a6a19b | 2010-12-14 11:29:51 +0300 | [diff] [blame] | 111 | 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] | 112 | extern const struct file_operations cifs_dir_ops; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 113 | extern int cifs_dir_open(struct inode *inode, struct file *file); |
Al Viro | be4ccdc | 2013-05-22 16:17:25 -0400 | [diff] [blame] | 114 | extern int cifs_readdir(struct file *file, struct dir_context *ctx); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 115 | |
| 116 | /* Functions related to dir entries */ |
Al Viro | 4fd03e8 | 2009-02-20 05:57:07 +0000 | [diff] [blame] | 117 | extern const struct dentry_operations cifs_dentry_ops; |
| 118 | extern const struct dentry_operations cifs_ci_dentry_ops; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 119 | |
David Howells | 01c64fe | 2011-01-14 18:45:47 +0000 | [diff] [blame] | 120 | #ifdef CONFIG_CIFS_DFS_UPCALL |
| 121 | extern struct vfsmount *cifs_dfs_d_automount(struct path *path); |
| 122 | #else |
| 123 | #define cifs_dfs_d_automount NULL |
| 124 | #endif |
| 125 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 126 | /* Functions related to symlinks */ |
Linus Torvalds | cc314ee | 2005-08-19 18:02:56 -0700 | [diff] [blame] | 127 | extern void *cifs_follow_link(struct dentry *direntry, struct nameidata *nd); |
Steve French | d38d8c7 | 2007-06-28 19:44:13 +0000 | [diff] [blame] | 128 | extern int cifs_readlink(struct dentry *direntry, char __user *buffer, |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 129 | int buflen); |
| 130 | extern int cifs_symlink(struct inode *inode, struct dentry *direntry, |
| 131 | const char *symname); |
| 132 | extern int cifs_removexattr(struct dentry *, const char *); |
Steve French | 13cd4b7 | 2010-10-07 18:46:32 +0000 | [diff] [blame] | 133 | extern int cifs_setxattr(struct dentry *, const char *, const void *, |
Steve French | f654bac | 2005-04-28 22:41:04 -0700 | [diff] [blame] | 134 | size_t, int); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 135 | extern ssize_t cifs_getxattr(struct dentry *, const char *, void *, size_t); |
| 136 | extern ssize_t cifs_listxattr(struct dentry *, char *, size_t); |
Steve French | f9ddcca | 2008-05-15 05:51:55 +0000 | [diff] [blame] | 137 | extern long cifs_ioctl(struct file *filep, unsigned int cmd, unsigned long arg); |
Steve French | 297647c | 2007-10-12 04:11:59 +0000 | [diff] [blame] | 138 | |
Paul Bolle | f3a6a60 | 2011-10-12 14:14:04 +0200 | [diff] [blame] | 139 | #ifdef CONFIG_CIFS_NFSD_EXPORT |
Christoph Hellwig | 3965516 | 2007-10-21 16:42:17 -0700 | [diff] [blame] | 140 | extern const struct export_operations cifs_export_ops; |
Paul Bolle | f3a6a60 | 2011-10-12 14:14:04 +0200 | [diff] [blame] | 141 | #endif /* CONFIG_CIFS_NFSD_EXPORT */ |
Steve French | 297647c | 2007-10-12 04:11:59 +0000 | [diff] [blame] | 142 | |
Steve French | ffe67b5 | 2013-09-25 19:01:27 -0500 | [diff] [blame] | 143 | #define CIFS_VERSION "2.02" |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 144 | #endif /* _CIFSFS_H */ |