4 * Copyright (c) International Business Machines Corp., 2002
5 * Author(s): Steve French (sfrench@us.ibm.com)
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.
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.
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
19 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
35 extern struct address_space_operations cifs_addr_ops
;
37 /* Functions related to super block operations */
38 extern struct super_operations cifs_super_ops
;
39 extern void cifs_read_inode(struct inode
*);
40 extern void cifs_delete_inode(struct inode
*);
41 /* extern void cifs_write_inode(struct inode *); *//* BB not needed yet */
43 /* Functions related to inodes */
44 extern struct inode_operations cifs_dir_inode_ops
;
45 extern int cifs_create(struct inode
*, struct dentry
*, int, struct nameidata
*);
46 extern struct dentry
*cifs_lookup(struct inode
*, struct dentry
*, struct nameidata
*);
47 extern int cifs_unlink(struct inode
*, struct dentry
*);
48 extern int cifs_hardlink(struct dentry
*, struct inode
*, struct dentry
*);
49 extern int cifs_mknod(struct inode
*, struct dentry
*, int, dev_t
);
50 extern int cifs_mkdir(struct inode
*, struct dentry
*, int);
51 extern int cifs_rmdir(struct inode
*, struct dentry
*);
52 extern int cifs_rename(struct inode
*, struct dentry
*, struct inode
*,
54 extern int cifs_revalidate(struct dentry
*);
55 extern int cifs_getattr(struct vfsmount
*, struct dentry
*, struct kstat
*);
56 extern int cifs_setattr(struct dentry
*, struct iattr
*);
58 extern struct inode_operations cifs_file_inode_ops
;
59 extern struct inode_operations cifs_symlink_inode_ops
;
61 /* Functions related to files and directories */
62 extern struct file_operations cifs_file_ops
;
63 extern int cifs_open(struct inode
*inode
, struct file
*file
);
64 extern int cifs_close(struct inode
*inode
, struct file
*file
);
65 extern int cifs_closedir(struct inode
*inode
, struct file
*file
);
66 extern ssize_t
cifs_read(struct file
*file
, char *read_data
,
67 size_t read_size
, loff_t
* poffset
);
68 extern ssize_t
cifs_write(struct file
*file
, const char *write_data
,
69 size_t write_size
, loff_t
* poffset
);
70 extern int cifs_lock(struct file
*, int, struct file_lock
*);
71 extern int cifs_fsync(struct file
*, struct dentry
*, int);
72 extern int cifs_flush(struct file
*);
73 extern int cifs_file_mmap(struct file
* , struct vm_area_struct
*);
74 extern struct file_operations cifs_dir_ops
;
75 extern int cifs_dir_open(struct inode
*inode
, struct file
*file
);
76 extern int cifs_readdir(struct file
*file
, void *direntry
, filldir_t filldir
);
77 extern int cifs_dir_notify(struct file
*, unsigned long arg
);
79 /* Functions related to dir entries */
80 extern struct dentry_operations cifs_dentry_ops
;
82 /* Functions related to symlinks */
83 extern int cifs_follow_link(struct dentry
*direntry
, struct nameidata
*nd
);
84 extern void cifs_put_link(struct dentry
*direntry
, struct nameidata
*nd
);
85 extern int cifs_readlink(struct dentry
*direntry
, char __user
*buffer
, int buflen
);
86 extern int cifs_symlink(struct inode
*inode
, struct dentry
*direntry
,
88 extern int cifs_removexattr(struct dentry
*, const char *);
89 extern int cifs_setxattr(struct dentry
*, const char *, const void *,
91 extern ssize_t
cifs_getxattr(struct dentry
*, const char *, void *, size_t);
92 extern ssize_t
cifs_listxattr(struct dentry
*, char *, size_t);
93 #define CIFS_VERSION "1.20"
94 #endif /* _CIFSFS_H */