forked from Minki/linux
ef14f0c157
This patch rips out the XFS ACL handling code and uses the generic fs/posix_acl.c code instead. The ondisk format is of course left unchanged. This also introduces the same ACL caching all other Linux filesystems do by adding pointers to the acl and default acl in struct xfs_inode. Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Eric Sandeen <sandeen@sandeen.net>
77 lines
3.3 KiB
C
77 lines
3.3 KiB
C
#ifndef _XFS_VNODEOPS_H
|
|
#define _XFS_VNODEOPS_H 1
|
|
|
|
struct attrlist_cursor_kern;
|
|
struct cred;
|
|
struct file;
|
|
struct iattr;
|
|
struct inode;
|
|
struct iovec;
|
|
struct kiocb;
|
|
struct pipe_inode_info;
|
|
struct uio;
|
|
struct xfs_inode;
|
|
struct xfs_iomap;
|
|
|
|
|
|
int xfs_setattr(struct xfs_inode *ip, struct iattr *vap, int flags);
|
|
#define XFS_ATTR_DMI 0x01 /* invocation from a DMI function */
|
|
#define XFS_ATTR_NONBLOCK 0x02 /* return EAGAIN if operation would block */
|
|
#define XFS_ATTR_NOLOCK 0x04 /* Don't grab any conflicting locks */
|
|
#define XFS_ATTR_NOACL 0x08 /* Don't call xfs_acl_chmod */
|
|
|
|
int xfs_readlink(struct xfs_inode *ip, char *link);
|
|
int xfs_fsync(struct xfs_inode *ip);
|
|
int xfs_release(struct xfs_inode *ip);
|
|
int xfs_inactive(struct xfs_inode *ip);
|
|
int xfs_lookup(struct xfs_inode *dp, struct xfs_name *name,
|
|
struct xfs_inode **ipp, struct xfs_name *ci_name);
|
|
int xfs_create(struct xfs_inode *dp, struct xfs_name *name, mode_t mode,
|
|
xfs_dev_t rdev, struct xfs_inode **ipp, cred_t *credp);
|
|
int xfs_remove(struct xfs_inode *dp, struct xfs_name *name,
|
|
struct xfs_inode *ip);
|
|
int xfs_link(struct xfs_inode *tdp, struct xfs_inode *sip,
|
|
struct xfs_name *target_name);
|
|
int xfs_readdir(struct xfs_inode *dp, void *dirent, size_t bufsize,
|
|
xfs_off_t *offset, filldir_t filldir);
|
|
int xfs_symlink(struct xfs_inode *dp, struct xfs_name *link_name,
|
|
const char *target_path, mode_t mode, struct xfs_inode **ipp,
|
|
cred_t *credp);
|
|
int xfs_set_dmattrs(struct xfs_inode *ip, u_int evmask, u_int16_t state);
|
|
int xfs_reclaim(struct xfs_inode *ip);
|
|
int xfs_change_file_space(struct xfs_inode *ip, int cmd,
|
|
xfs_flock64_t *bf, xfs_off_t offset, int attr_flags);
|
|
int xfs_rename(struct xfs_inode *src_dp, struct xfs_name *src_name,
|
|
struct xfs_inode *src_ip, struct xfs_inode *target_dp,
|
|
struct xfs_name *target_name, struct xfs_inode *target_ip);
|
|
int xfs_attr_get(struct xfs_inode *ip, const char *name, char *value,
|
|
int *valuelenp, int flags);
|
|
int xfs_attr_set(struct xfs_inode *dp, const char *name, char *value,
|
|
int valuelen, int flags);
|
|
int xfs_attr_remove(struct xfs_inode *dp, const char *name, int flags);
|
|
int xfs_attr_list(struct xfs_inode *dp, char *buffer, int bufsize,
|
|
int flags, struct attrlist_cursor_kern *cursor);
|
|
ssize_t xfs_read(struct xfs_inode *ip, struct kiocb *iocb,
|
|
const struct iovec *iovp, unsigned int segs,
|
|
loff_t *offset, int ioflags);
|
|
ssize_t xfs_splice_read(struct xfs_inode *ip, struct file *infilp,
|
|
loff_t *ppos, struct pipe_inode_info *pipe, size_t count,
|
|
int flags, int ioflags);
|
|
ssize_t xfs_splice_write(struct xfs_inode *ip,
|
|
struct pipe_inode_info *pipe, struct file *outfilp,
|
|
loff_t *ppos, size_t count, int flags, int ioflags);
|
|
ssize_t xfs_write(struct xfs_inode *xip, struct kiocb *iocb,
|
|
const struct iovec *iovp, unsigned int nsegs,
|
|
loff_t *offset, int ioflags);
|
|
int xfs_bmap(struct xfs_inode *ip, xfs_off_t offset, ssize_t count,
|
|
int flags, struct xfs_iomap *iomapp, int *niomaps);
|
|
void xfs_tosspages(struct xfs_inode *inode, xfs_off_t first,
|
|
xfs_off_t last, int fiopt);
|
|
int xfs_flushinval_pages(struct xfs_inode *ip, xfs_off_t first,
|
|
xfs_off_t last, int fiopt);
|
|
int xfs_flush_pages(struct xfs_inode *ip, xfs_off_t first,
|
|
xfs_off_t last, uint64_t flags, int fiopt);
|
|
int xfs_wait_on_pages(struct xfs_inode *ip, xfs_off_t first, xfs_off_t last);
|
|
|
|
#endif /* _XFS_VNODEOPS_H */
|