Merge branch 'miklos.fileattr' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs
Pull fileattr conversion updates from Miklos Szeredi via Al Viro: "This splits the handling of FS_IOC_[GS]ETFLAGS from ->ioctl() into a separate method. The interface is reasonably uniform across the filesystems that support it and gives nice boilerplate removal" * 'miklos.fileattr' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs: (23 commits) ovl: remove unneeded ioctls fuse: convert to fileattr fuse: add internal open/release helpers fuse: unsigned open flags fuse: move ioctl to separate source file vfs: remove unused ioctl helpers ubifs: convert to fileattr reiserfs: convert to fileattr ocfs2: convert to fileattr nilfs2: convert to fileattr jfs: convert to fileattr hfsplus: convert to fileattr efivars: convert to fileattr xfs: convert to fileattr orangefs: convert to fileattr gfs2: convert to fileattr f2fs: convert to fileattr ext4: convert to fileattr ext2: convert to fileattr btrfs: convert to fileattr ...
This commit is contained in:
commit
a4f7fae101
71 changed files with 1738 additions and 2021 deletions
59
include/linux/fileattr.h
Normal file
59
include/linux/fileattr.h
Normal file
|
|
@ -0,0 +1,59 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0 */
|
||||
|
||||
#ifndef _LINUX_FILEATTR_H
|
||||
#define _LINUX_FILEATTR_H
|
||||
|
||||
/* Flags shared betwen flags/xflags */
|
||||
#define FS_COMMON_FL \
|
||||
(FS_SYNC_FL | FS_IMMUTABLE_FL | FS_APPEND_FL | \
|
||||
FS_NODUMP_FL | FS_NOATIME_FL | FS_DAX_FL | \
|
||||
FS_PROJINHERIT_FL)
|
||||
|
||||
#define FS_XFLAG_COMMON \
|
||||
(FS_XFLAG_SYNC | FS_XFLAG_IMMUTABLE | FS_XFLAG_APPEND | \
|
||||
FS_XFLAG_NODUMP | FS_XFLAG_NOATIME | FS_XFLAG_DAX | \
|
||||
FS_XFLAG_PROJINHERIT)
|
||||
|
||||
/*
|
||||
* Merged interface for miscellaneous file attributes. 'flags' originates from
|
||||
* ext* and 'fsx_flags' from xfs. There's some overlap between the two, which
|
||||
* is handled by the VFS helpers, so filesystems are free to implement just one
|
||||
* or both of these sub-interfaces.
|
||||
*/
|
||||
struct fileattr {
|
||||
u32 flags; /* flags (FS_IOC_GETFLAGS/FS_IOC_SETFLAGS) */
|
||||
/* struct fsxattr: */
|
||||
u32 fsx_xflags; /* xflags field value (get/set) */
|
||||
u32 fsx_extsize; /* extsize field value (get/set)*/
|
||||
u32 fsx_nextents; /* nextents field value (get) */
|
||||
u32 fsx_projid; /* project identifier (get/set) */
|
||||
u32 fsx_cowextsize; /* CoW extsize field value (get/set)*/
|
||||
/* selectors: */
|
||||
bool flags_valid:1;
|
||||
bool fsx_valid:1;
|
||||
};
|
||||
|
||||
int copy_fsxattr_to_user(const struct fileattr *fa, struct fsxattr __user *ufa);
|
||||
|
||||
void fileattr_fill_xflags(struct fileattr *fa, u32 xflags);
|
||||
void fileattr_fill_flags(struct fileattr *fa, u32 flags);
|
||||
|
||||
/**
|
||||
* fileattr_has_fsx - check for extended flags/attributes
|
||||
* @fa: fileattr pointer
|
||||
*
|
||||
* Return: true if any attributes are present that are not represented in
|
||||
* ->flags.
|
||||
*/
|
||||
static inline bool fileattr_has_fsx(const struct fileattr *fa)
|
||||
{
|
||||
return fa->fsx_valid &&
|
||||
((fa->fsx_xflags & ~FS_XFLAG_COMMON) || fa->fsx_extsize != 0 ||
|
||||
fa->fsx_projid != 0 || fa->fsx_cowextsize != 0);
|
||||
}
|
||||
|
||||
int vfs_fileattr_get(struct dentry *dentry, struct fileattr *fa);
|
||||
int vfs_fileattr_set(struct user_namespace *mnt_userns, struct dentry *dentry,
|
||||
struct fileattr *fa);
|
||||
|
||||
#endif /* _LINUX_FILEATTR_H */
|
||||
|
|
@ -70,6 +70,7 @@ struct fsverity_info;
|
|||
struct fsverity_operations;
|
||||
struct fs_context;
|
||||
struct fs_parameter_spec;
|
||||
struct fileattr;
|
||||
|
||||
extern void __init inode_init(void);
|
||||
extern void __init inode_init_early(void);
|
||||
|
|
@ -1963,6 +1964,9 @@ struct inode_operations {
|
|||
struct dentry *, umode_t);
|
||||
int (*set_acl)(struct user_namespace *, struct inode *,
|
||||
struct posix_acl *, int);
|
||||
int (*fileattr_set)(struct user_namespace *mnt_userns,
|
||||
struct dentry *dentry, struct fileattr *fa);
|
||||
int (*fileattr_get)(struct dentry *dentry, struct fileattr *fa);
|
||||
} ____cacheline_aligned;
|
||||
|
||||
static inline ssize_t call_read_iter(struct file *file, struct kiocb *kio,
|
||||
|
|
@ -3572,18 +3576,6 @@ extern int vfs_fadvise(struct file *file, loff_t offset, loff_t len,
|
|||
extern int generic_fadvise(struct file *file, loff_t offset, loff_t len,
|
||||
int advice);
|
||||
|
||||
int vfs_ioc_setflags_prepare(struct inode *inode, unsigned int oldflags,
|
||||
unsigned int flags);
|
||||
|
||||
int vfs_ioc_fssetxattr_check(struct inode *inode, const struct fsxattr *old_fa,
|
||||
struct fsxattr *fa);
|
||||
|
||||
static inline void simple_fill_fsxattr(struct fsxattr *fa, __u32 xflags)
|
||||
{
|
||||
memset(fa, 0, sizeof(*fa));
|
||||
fa->fsx_xflags = xflags;
|
||||
}
|
||||
|
||||
/*
|
||||
* Flush file data before changing attributes. Caller must hold any locks
|
||||
* required to prevent further writes to this file until we're done setting
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue