blob: 38c67c34d73f49848a91223988cf4cdf46ffb5ce [file] [log] [blame]
Christoph Hellwig993386c2007-08-28 16:12:30 +10001#ifndef _XFS_VNODEOPS_H
2#define _XFS_VNODEOPS_H 1
3
4struct attrlist_cursor_kern;
Christoph Hellwig993386c2007-08-28 16:12:30 +10005struct file;
Christoph Hellwig0f285c82008-07-18 17:13:28 +10006struct iattr;
Christoph Hellwig993386c2007-08-28 16:12:30 +10007struct inode;
8struct iovec;
9struct kiocb;
10struct pipe_inode_info;
11struct uio;
12struct xfs_inode;
Christoph Hellwig993386c2007-08-28 16:12:30 +100013
14
Christoph Hellwigc4ed4242011-07-08 14:34:23 +020015int xfs_setattr_nonsize(struct xfs_inode *ip, struct iattr *vap, int flags);
16int xfs_setattr_size(struct xfs_inode *ip, struct iattr *vap, int flags);
Christoph Hellwig0f285c82008-07-18 17:13:28 +100017#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 Hellwigef14f0c2009-06-10 17:07:47 +020020#define XFS_ATTR_NOACL 0x08 /* Don't call xfs_acl_chmod */
Dave Chinner82878892011-03-26 09:13:08 +110021#define XFS_ATTR_SYNC 0x10 /* synchronous operation required */
Christoph Hellwig0f285c82008-07-18 17:13:28 +100022
Christoph Hellwig993386c2007-08-28 16:12:30 +100023int xfs_readlink(struct xfs_inode *ip, char *link);
Christoph Hellwig993386c2007-08-28 16:12:30 +100024int xfs_release(struct xfs_inode *ip);
25int xfs_inactive(struct xfs_inode *ip);
Barry Naujok556b8b12008-04-10 12:22:07 +100026int xfs_lookup(struct xfs_inode *dp, struct xfs_name *name,
Barry Naujok384f3ce2008-05-21 16:58:22 +100027 struct xfs_inode **ipp, struct xfs_name *ci_name);
Al Viro576b1d62011-07-26 02:50:15 -040028int xfs_create(struct xfs_inode *dp, struct xfs_name *name, umode_t mode,
Christoph Hellwig6c77b0e2010-10-06 18:41:17 +000029 xfs_dev_t rdev, struct xfs_inode **ipp);
Barry Naujok556b8b12008-04-10 12:22:07 +100030int xfs_remove(struct xfs_inode *dp, struct xfs_name *name,
31 struct xfs_inode *ip);
Christoph Hellwiga3da7892008-03-06 13:46:12 +110032int xfs_link(struct xfs_inode *tdp, struct xfs_inode *sip,
Barry Naujok556b8b12008-04-10 12:22:07 +100033 struct xfs_name *target_name);
Al Virob8227552013-05-22 17:07:56 -040034int xfs_readdir(struct xfs_inode *dp, struct dir_context *ctx, size_t bufsize);
Barry Naujok556b8b12008-04-10 12:22:07 +100035int xfs_symlink(struct xfs_inode *dp, struct xfs_name *link_name,
Al Viro576b1d62011-07-26 02:50:15 -040036 const char *target_path, umode_t mode, struct xfs_inode **ipp);
Christoph Hellwig993386c2007-08-28 16:12:30 +100037int xfs_set_dmattrs(struct xfs_inode *ip, u_int evmask, u_int16_t state);
Christoph Hellwig993386c2007-08-28 16:12:30 +100038int xfs_change_file_space(struct xfs_inode *ip, int cmd,
Christoph Hellwigea5a3dc82008-10-30 18:27:48 +110039 xfs_flock64_t *bf, xfs_off_t offset, int attr_flags);
Barry Naujok556b8b12008-04-10 12:22:07 +100040int xfs_rename(struct xfs_inode *src_dp, struct xfs_name *src_name,
41 struct xfs_inode *src_ip, struct xfs_inode *target_dp,
Christoph Hellwigcfa853e2008-04-22 17:34:06 +100042 struct xfs_name *target_name, struct xfs_inode *target_ip);
Dave Chinnera9273ca2010-01-20 10:47:48 +110043int xfs_attr_get(struct xfs_inode *ip, const unsigned char *name,
44 unsigned char *value, int *valuelenp, int flags);
45int xfs_attr_set(struct xfs_inode *dp, const unsigned char *name,
46 unsigned char *value, int valuelen, int flags);
47int xfs_attr_remove(struct xfs_inode *dp, const unsigned char *name, int flags);
Christoph Hellwig993386c2007-08-28 16:12:30 +100048int xfs_attr_list(struct xfs_inode *dp, char *buffer, int bufsize,
49 int flags, struct attrlist_cursor_kern *cursor);
Christoph Hellwig993386c2007-08-28 16:12:30 +100050
Dave Chinneref9d8732012-11-29 15:26:33 +110051int xfs_iozero(struct xfs_inode *, loff_t, size_t);
Christoph Hellwigd7658d42010-02-17 19:36:13 +000052int xfs_zero_eof(struct xfs_inode *, xfs_off_t, xfs_fsize_t);
Brian Foster40165e22012-11-06 09:50:41 -050053int xfs_free_eofblocks(struct xfs_mount *, struct xfs_inode *, bool);
Christoph Hellwigd7658d42010-02-17 19:36:13 +000054
Christoph Hellwig993386c2007-08-28 16:12:30 +100055#endif /* _XFS_VNODEOPS_H */