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 cred; |
| 6 | struct file; |
Christoph Hellwig | 0f285c8 | 2008-07-18 17:13:28 +1000 | [diff] [blame] | 7 | struct iattr; |
Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 8 | struct inode; |
| 9 | struct iovec; |
| 10 | struct kiocb; |
| 11 | struct pipe_inode_info; |
| 12 | struct uio; |
| 13 | struct xfs_inode; |
| 14 | struct xfs_iomap; |
| 15 | |
| 16 | |
Christoph Hellwig | ea5a3dc8 | 2008-10-30 18:27:48 +1100 | [diff] [blame] | 17 | int xfs_setattr(struct xfs_inode *ip, struct iattr *vap, int flags); |
Christoph Hellwig | 0f285c8 | 2008-07-18 17:13:28 +1000 | [diff] [blame] | 18 | #define XFS_ATTR_DMI 0x01 /* invocation from a DMI function */ |
| 19 | #define XFS_ATTR_NONBLOCK 0x02 /* return EAGAIN if operation would block */ |
| 20 | #define XFS_ATTR_NOLOCK 0x04 /* Don't grab any conflicting locks */ |
| 21 | |
Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 22 | int xfs_readlink(struct xfs_inode *ip, char *link); |
David Chinner | 978b723 | 2008-05-19 16:29:46 +1000 | [diff] [blame] | 23 | int xfs_fsync(struct xfs_inode *ip); |
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); |
Barry Naujok | 556b8b1 | 2008-04-10 12:22:07 +1000 | [diff] [blame] | 28 | int xfs_create(struct xfs_inode *dp, struct xfs_name *name, mode_t mode, |
David Howells | b6dff3e | 2008-11-14 10:39:16 +1100 | [diff] [blame] | 29 | xfs_dev_t rdev, struct xfs_inode **ipp, cred_t *credp); |
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, |
| 37 | const char *target_path, mode_t mode, struct xfs_inode **ipp, |
David Howells | b6dff3e | 2008-11-14 10:39:16 +1100 | [diff] [blame] | 38 | cred_t *credp); |
Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 39 | int xfs_set_dmattrs(struct xfs_inode *ip, u_int evmask, u_int16_t state); |
| 40 | int xfs_reclaim(struct xfs_inode *ip); |
| 41 | int xfs_change_file_space(struct xfs_inode *ip, int cmd, |
Christoph Hellwig | ea5a3dc8 | 2008-10-30 18:27:48 +1100 | [diff] [blame] | 42 | xfs_flock64_t *bf, xfs_off_t offset, int attr_flags); |
Barry Naujok | 556b8b1 | 2008-04-10 12:22:07 +1000 | [diff] [blame] | 43 | int xfs_rename(struct xfs_inode *src_dp, struct xfs_name *src_name, |
| 44 | struct xfs_inode *src_ip, struct xfs_inode *target_dp, |
Christoph Hellwig | cfa853e | 2008-04-22 17:34:06 +1000 | [diff] [blame] | 45 | struct xfs_name *target_name, struct xfs_inode *target_ip); |
Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 46 | int xfs_attr_get(struct xfs_inode *ip, const char *name, char *value, |
Barry Naujok | e8b0eba | 2008-04-22 17:34:31 +1000 | [diff] [blame] | 47 | int *valuelenp, int flags); |
Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 48 | int xfs_attr_set(struct xfs_inode *dp, const char *name, char *value, |
| 49 | int valuelen, int flags); |
| 50 | int xfs_attr_remove(struct xfs_inode *dp, const char *name, int flags); |
| 51 | int xfs_attr_list(struct xfs_inode *dp, char *buffer, int bufsize, |
| 52 | int flags, struct attrlist_cursor_kern *cursor); |
Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 53 | ssize_t xfs_read(struct xfs_inode *ip, struct kiocb *iocb, |
| 54 | const struct iovec *iovp, unsigned int segs, |
| 55 | loff_t *offset, int ioflags); |
Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 56 | ssize_t xfs_splice_read(struct xfs_inode *ip, struct file *infilp, |
| 57 | loff_t *ppos, struct pipe_inode_info *pipe, size_t count, |
| 58 | int flags, int ioflags); |
| 59 | ssize_t xfs_splice_write(struct xfs_inode *ip, |
| 60 | struct pipe_inode_info *pipe, struct file *outfilp, |
| 61 | loff_t *ppos, size_t count, int flags, int ioflags); |
| 62 | ssize_t xfs_write(struct xfs_inode *xip, struct kiocb *iocb, |
| 63 | const struct iovec *iovp, unsigned int nsegs, |
| 64 | loff_t *offset, int ioflags); |
| 65 | int xfs_bmap(struct xfs_inode *ip, xfs_off_t offset, ssize_t count, |
| 66 | int flags, struct xfs_iomap *iomapp, int *niomaps); |
| 67 | void xfs_tosspages(struct xfs_inode *inode, xfs_off_t first, |
| 68 | xfs_off_t last, int fiopt); |
| 69 | int xfs_flushinval_pages(struct xfs_inode *ip, xfs_off_t first, |
| 70 | xfs_off_t last, int fiopt); |
| 71 | int xfs_flush_pages(struct xfs_inode *ip, xfs_off_t first, |
| 72 | xfs_off_t last, uint64_t flags, int fiopt); |
Dave Chinner | 2e65609 | 2008-11-28 14:23:33 +1100 | [diff] [blame] | 73 | int xfs_wait_on_pages(struct xfs_inode *ip, xfs_off_t first, xfs_off_t last); |
Christoph Hellwig | 993386c | 2007-08-28 16:12:30 +1000 | [diff] [blame] | 74 | |
| 75 | #endif /* _XFS_VNODEOPS_H */ |