6fed42bb77
To implement snapshots, we need every filesystem btree operation (every btree operation without a subvolume) to start by looking up the subvolume and getting the current snapshot ID, with bch2_subvolume_get_snapshot() - then, that snapshot ID is used for doing btree lookups in BTREE_ITER_FILTER_SNAPSHOTS mode. This patch adds those bch2_subvolume_get_snapshot() calls, and also switches to passing around a subvol_inum instead of just an inode number. Signed-off-by: Kent Overstreet <kent.overstreet@gmail.com>
59 lines
1.3 KiB
C
59 lines
1.3 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef _BCACHEFS_ACL_H
|
|
#define _BCACHEFS_ACL_H
|
|
|
|
struct bch_inode_unpacked;
|
|
struct bch_hash_info;
|
|
struct bch_inode_info;
|
|
struct posix_acl;
|
|
|
|
#ifdef CONFIG_BCACHEFS_POSIX_ACL
|
|
|
|
#define BCH_ACL_VERSION 0x0001
|
|
|
|
typedef struct {
|
|
__le16 e_tag;
|
|
__le16 e_perm;
|
|
__le32 e_id;
|
|
} bch_acl_entry;
|
|
|
|
typedef struct {
|
|
__le16 e_tag;
|
|
__le16 e_perm;
|
|
} bch_acl_entry_short;
|
|
|
|
typedef struct {
|
|
__le32 a_version;
|
|
} bch_acl_header;
|
|
|
|
struct posix_acl *bch2_get_acl(struct mnt_idmap *, struct dentry *, int);
|
|
|
|
int bch2_set_acl_trans(struct btree_trans *, subvol_inum,
|
|
struct bch_inode_unpacked *,
|
|
struct posix_acl *, int);
|
|
int bch2_set_acl(struct mnt_idmap *, struct dentry *, struct posix_acl *, int);
|
|
int bch2_acl_chmod(struct btree_trans *, subvol_inum,
|
|
struct bch_inode_unpacked *,
|
|
umode_t, struct posix_acl **);
|
|
|
|
#else
|
|
|
|
static inline int bch2_set_acl_trans(struct btree_trans *trans, subvol_inum inum,
|
|
struct bch_inode_unpacked *inode_u,
|
|
struct posix_acl *acl, int type)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static inline int bch2_acl_chmod(struct btree_trans *trans, subvol_inum inum,
|
|
struct bch_inode_unpacked *inode,
|
|
umode_t mode,
|
|
struct posix_acl **new_acl)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
#endif /* CONFIG_BCACHEFS_POSIX_ACL */
|
|
|
|
#endif /* _BCACHEFS_ACL_H */
|