📄 cifsfs.h
字号:
/* * fs/cifs/cifsfs.h * * Copyright (c) International Business Machines Corp., 2002, 2005 * Author(s): Steve French (sfrench@us.ibm.com) * * This library is free software; you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published * by the Free Software Foundation; either version 2.1 of the License, or * (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See * the GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */#ifndef _CIFSFS_H#define _CIFSFS_H#define ROOT_I 2#ifndef FALSE#define FALSE 0#endif#ifndef TRUE#define TRUE 1#endif#include <linux/version.h>#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,11)#define current_fs_time(arg) CURRENT_TIME#endif#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 4, 25)#define filemap_fdatawrite filemap_fdatasync#endif#if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)static inline int timespec_equal(time_t *time1, time_t *time2){ return (time1 == time2);}static inline void invalidate_remote_inode(struct inode * inode){ invalidate_inode_pages(inode);}static inline void i_size_write(struct inode *inode, loff_t size){ inode->i_size = size;}#ifndef PageUptodate#define PageUptodate(page) Page_Uptodate(page)#endif#endifextern const struct address_space_operations cifs_addr_ops;extern const struct address_space_operations cifs_addr_ops_smallbuf;/* Functions related to super block operations *//* extern const struct super_operations cifs_super_ops;*/extern void cifs_read_inode(struct inode *);/*extern void cifs_delete_inode(struct inode *);*/ /* BB not needed yet *//* extern void cifs_write_inode(struct inode *); */ /* BB not needed yet *//* Functions related to inodes */extern const struct inode_operations cifs_dir_inode_ops;#if LINUX_VERSION_CODE > KERNEL_VERSION(2, 5, 0)extern int cifs_create(struct inode *, struct dentry *, int, struct nameidata *);extern struct dentry * cifs_lookup(struct inode *, struct dentry *, struct nameidata *);extern int cifs_mknod(struct inode *, struct dentry *, int, dev_t);extern int cifs_getattr(struct vfsmount *, struct dentry *, struct kstat *);#elseextern int cifs_create(struct inode *, struct dentry *, int);extern struct dentry * cifs_lookup(struct inode *, struct dentry *);extern int cifs_mknod(struct inode *, struct dentry *, int, int);#endifextern int cifs_unlink(struct inode *, struct dentry *);extern int cifs_hardlink(struct dentry *, struct inode *, struct dentry *);extern int cifs_mkdir(struct inode *, struct dentry *, int);extern int cifs_rmdir(struct inode *, struct dentry *);extern int cifs_rename(struct inode *, struct dentry *, struct inode *, struct dentry *);extern int cifs_revalidate(struct dentry *);extern int cifs_setattr(struct dentry *, struct iattr *);extern const struct inode_operations cifs_file_inode_ops;extern const struct inode_operations cifs_symlink_inode_ops;/* Functions related to files and directories */extern const struct file_operations cifs_file_ops;extern const struct file_operations cifs_file_direct_ops; /* if directio mnt */extern const struct file_operations cifs_file_nobrl_ops;extern const struct file_operations cifs_file_direct_nobrl_ops; /* no brlocks */extern int cifs_open(struct inode *inode, struct file *file);extern int cifs_close(struct inode *inode, struct file *file);extern int cifs_closedir(struct inode *inode, struct file *file);extern ssize_t cifs_user_read(struct file *file, char __user *read_data, size_t read_size, loff_t *poffset);extern ssize_t cifs_user_write(struct file *file, const char __user *write_data, size_t write_size, loff_t *poffset);extern int cifs_lock(struct file *, int, struct file_lock *);extern int cifs_fsync(struct file *, struct dentry *, int);#if LINUX_VERSION_CODE > KERNEL_VERSION(2,6,17)extern int cifs_flush(struct file *, fl_owner_t id);#elseextern int cifs_flush(struct file *);#endif /* 2.6.17 */extern int cifs_file_mmap(struct file * , struct vm_area_struct *);extern const struct file_operations cifs_dir_ops;extern int cifs_dir_open(struct inode *inode, struct file *file);extern int cifs_readdir(struct file *file, void *direntry, filldir_t filldir);extern int cifs_dir_notify(struct file *, unsigned long arg);/* Functions related to dir entries */extern struct dentry_operations cifs_dentry_ops;extern struct dentry_operations cifs_ci_dentry_ops;/* Functions related to symlinks */#if LINUX_VERSION_CODE > KERNEL_VERSION(2,6,12)extern void *cifs_follow_link(struct dentry *direntry, struct nameidata *nd);extern void cifs_put_link(struct dentry *direntry, struct nameidata *nd, void *);#elseextern int cifs_follow_link(struct dentry *direntry, struct nameidata *nd);extern void cifs_put_link(struct dentry *direntry, struct nameidata *nd);#endifextern int cifs_readlink(struct dentry *direntry, char __user *buffer, int buflen);extern int cifs_symlink(struct inode *inode, struct dentry *direntry, const char *symname);extern int cifs_removexattr(struct dentry *, const char *);extern int cifs_setxattr(struct dentry *, const char *, const void *, size_t, int);extern ssize_t cifs_getxattr(struct dentry *, const char *, void *, size_t);extern ssize_t cifs_listxattr(struct dentry *, char *, size_t);extern int cifs_ioctl(struct inode *inode, struct file *filep, unsigned int command, unsigned long arg);#define CIFS_VERSION "1.51"#endif /* _CIFSFS_H */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -