| Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 1 | #ifndef _XFS_VNODEOPS_H | 
|  | 2 | #define _XFS_VNODEOPS_H 1 | 
|  | 3 |  | 
|  | 4 | struct attrlist_cursor_kern; | 
| Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 5 | struct file; | 
| Christoph Hellwig | 0f285c8 | 2008-07-18 17:13:28 +1000 | [diff] [blame] | 6 | struct iattr; | 
| Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 7 | struct inode; | 
|  | 8 | struct iovec; | 
|  | 9 | struct kiocb; | 
|  | 10 | struct pipe_inode_info; | 
|  | 11 | struct uio; | 
|  | 12 | struct xfs_inode; | 
| Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 13 |  | 
|  | 14 |  | 
| Christoph Hellwig | c4ed424 | 2011-07-08 14:34:23 +0200 | [diff] [blame] | 15 | int xfs_setattr_nonsize(struct xfs_inode *ip, struct iattr *vap, int flags); | 
|  | 16 | int xfs_setattr_size(struct xfs_inode *ip, struct iattr *vap, int flags); | 
| Christoph Hellwig | 0f285c8 | 2008-07-18 17:13:28 +1000 | [diff] [blame] | 17 | #define	XFS_ATTR_DMI		0x01	/* invocation from a DMI function */ | 
|  | 18 | #define	XFS_ATTR_NONBLOCK	0x02	/* return EAGAIN if operation would block */ | 
|  | 19 | #define XFS_ATTR_NOLOCK		0x04	/* Don't grab any conflicting locks */ | 
| Christoph Hellwig | ef14f0c | 2009-06-10 17:07:47 +0200 | [diff] [blame] | 20 | #define XFS_ATTR_NOACL		0x08	/* Don't call xfs_acl_chmod */ | 
| Dave Chinner | 8287889 | 2011-03-26 09:13:08 +1100 | [diff] [blame] | 21 | #define XFS_ATTR_SYNC		0x10	/* synchronous operation required */ | 
| Christoph Hellwig | 0f285c8 | 2008-07-18 17:13:28 +1000 | [diff] [blame] | 22 |  | 
| Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 23 | int xfs_readlink(struct xfs_inode *ip, char *link); | 
| Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 24 | int xfs_release(struct xfs_inode *ip); | 
|  | 25 | int xfs_inactive(struct xfs_inode *ip); | 
| Barry Naujok | 556b8b1 | 2008-04-10 12:22:07 +1000 | [diff] [blame] | 26 | int xfs_lookup(struct xfs_inode *dp, struct xfs_name *name, | 
| Barry Naujok | 384f3ce | 2008-05-21 16:58:22 +1000 | [diff] [blame] | 27 | struct xfs_inode **ipp, struct xfs_name *ci_name); | 
| Al Viro | 576b1d6 | 2011-07-26 02:50:15 -0400 | [diff] [blame] | 28 | int xfs_create(struct xfs_inode *dp, struct xfs_name *name, umode_t mode, | 
| Christoph Hellwig | 6c77b0e | 2010-10-06 18:41:17 +0000 | [diff] [blame] | 29 | xfs_dev_t rdev, struct xfs_inode **ipp); | 
| Barry Naujok | 556b8b1 | 2008-04-10 12:22:07 +1000 | [diff] [blame] | 30 | int xfs_remove(struct xfs_inode *dp, struct xfs_name *name, | 
|  | 31 | struct xfs_inode *ip); | 
| Christoph Hellwig | a3da789 | 2008-03-06 13:46:12 +1100 | [diff] [blame] | 32 | int xfs_link(struct xfs_inode *tdp, struct xfs_inode *sip, | 
| Barry Naujok | 556b8b1 | 2008-04-10 12:22:07 +1000 | [diff] [blame] | 33 | struct xfs_name *target_name); | 
| Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 34 | int xfs_readdir(struct xfs_inode	*dp, void *dirent, size_t bufsize, | 
|  | 35 | xfs_off_t *offset, filldir_t filldir); | 
| Barry Naujok | 556b8b1 | 2008-04-10 12:22:07 +1000 | [diff] [blame] | 36 | int xfs_symlink(struct xfs_inode *dp, struct xfs_name *link_name, | 
| Al Viro | 576b1d6 | 2011-07-26 02:50:15 -0400 | [diff] [blame] | 37 | const char *target_path, umode_t mode, struct xfs_inode **ipp); | 
| Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 38 | int xfs_set_dmattrs(struct xfs_inode *ip, u_int evmask, u_int16_t state); | 
| Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 39 | int xfs_change_file_space(struct xfs_inode *ip, int cmd, | 
| Christoph Hellwig | ea5a3dc8 | 2008-10-30 18:27:48 +1100 | [diff] [blame] | 40 | xfs_flock64_t *bf, xfs_off_t offset, int attr_flags); | 
| Barry Naujok | 556b8b1 | 2008-04-10 12:22:07 +1000 | [diff] [blame] | 41 | int xfs_rename(struct xfs_inode *src_dp, struct xfs_name *src_name, | 
|  | 42 | struct xfs_inode *src_ip, struct xfs_inode *target_dp, | 
| Christoph Hellwig | cfa853e | 2008-04-22 17:34:06 +1000 | [diff] [blame] | 43 | struct xfs_name *target_name, struct xfs_inode *target_ip); | 
| Dave Chinner | a9273ca | 2010-01-20 10:47:48 +1100 | [diff] [blame] | 44 | int xfs_attr_get(struct xfs_inode *ip, const unsigned char *name, | 
|  | 45 | unsigned char *value, int *valuelenp, int flags); | 
|  | 46 | int xfs_attr_set(struct xfs_inode *dp, const unsigned char *name, | 
|  | 47 | unsigned char *value, int valuelen, int flags); | 
|  | 48 | int xfs_attr_remove(struct xfs_inode *dp, const unsigned char *name, int flags); | 
| Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 49 | int xfs_attr_list(struct xfs_inode *dp, char *buffer, int bufsize, | 
|  | 50 | int flags, struct attrlist_cursor_kern *cursor); | 
| Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 51 |  | 
| Dave Chinner | ef9d873 | 2012-11-29 15:26:33 +1100 | [diff] [blame] | 52 | int xfs_iozero(struct xfs_inode *, loff_t, size_t); | 
| Christoph Hellwig | d7658d4 | 2010-02-17 19:36:13 +0000 | [diff] [blame] | 53 | int xfs_zero_eof(struct xfs_inode *, xfs_off_t, xfs_fsize_t); | 
| Brian Foster | 40165e2 | 2012-11-06 09:50:41 -0500 | [diff] [blame] | 54 | int xfs_free_eofblocks(struct xfs_mount *, struct xfs_inode *, bool); | 
| Christoph Hellwig | d7658d4 | 2010-02-17 19:36:13 +0000 | [diff] [blame] | 55 |  | 
| Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 56 | #endif /* _XFS_VNODEOPS_H */ |