mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-16 18:26:42 +00:00
d97de0d017
bkey_fsck_err() was added as an interface that looks like fsck_err(), but previously all it did was ensure that the appropriate error counter was incremented in the superblock. This is a cleanup and bugfix patch that converts it to a wrapper around fsck_err(). This is needed to fix an issue with the upgrade path to disk_accounting_v3, where the "silent fix" error list now includes bkey_fsck errors; fsck_err() handles this in a unified way, and since we need to change printing of bkey fsck errors from the caller to the inner bkey_fsck_err() calls, this ends up being a pretty big change. Als,, rename .invalid() methods to .validate(), for clarity, while we're changing the function signature anyways (to drop the printbuf argument). Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
76 lines
2.3 KiB
C
76 lines
2.3 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef _BCACHEFS_DIRENT_H
|
|
#define _BCACHEFS_DIRENT_H
|
|
|
|
#include "str_hash.h"
|
|
|
|
enum bch_validate_flags;
|
|
extern const struct bch_hash_desc bch2_dirent_hash_desc;
|
|
|
|
int bch2_dirent_validate(struct bch_fs *, struct bkey_s_c, enum bch_validate_flags);
|
|
void bch2_dirent_to_text(struct printbuf *, struct bch_fs *, struct bkey_s_c);
|
|
|
|
#define bch2_bkey_ops_dirent ((struct bkey_ops) { \
|
|
.key_validate = bch2_dirent_validate, \
|
|
.val_to_text = bch2_dirent_to_text, \
|
|
.min_val_size = 16, \
|
|
})
|
|
|
|
struct qstr;
|
|
struct file;
|
|
struct dir_context;
|
|
struct bch_fs;
|
|
struct bch_hash_info;
|
|
struct bch_inode_info;
|
|
|
|
struct qstr bch2_dirent_get_name(struct bkey_s_c_dirent d);
|
|
|
|
static inline unsigned dirent_val_u64s(unsigned len)
|
|
{
|
|
return DIV_ROUND_UP(offsetof(struct bch_dirent, d_name) + len,
|
|
sizeof(u64));
|
|
}
|
|
|
|
int bch2_dirent_read_target(struct btree_trans *, subvol_inum,
|
|
struct bkey_s_c_dirent, subvol_inum *);
|
|
|
|
int bch2_dirent_create_snapshot(struct btree_trans *, u32, u64, u32,
|
|
const struct bch_hash_info *, u8,
|
|
const struct qstr *, u64, u64 *,
|
|
enum btree_iter_update_trigger_flags);
|
|
int bch2_dirent_create(struct btree_trans *, subvol_inum,
|
|
const struct bch_hash_info *, u8,
|
|
const struct qstr *, u64, u64 *,
|
|
enum btree_iter_update_trigger_flags);
|
|
|
|
static inline unsigned vfs_d_type(unsigned type)
|
|
{
|
|
return type == DT_SUBVOL ? DT_DIR : type;
|
|
}
|
|
|
|
enum bch_rename_mode {
|
|
BCH_RENAME,
|
|
BCH_RENAME_OVERWRITE,
|
|
BCH_RENAME_EXCHANGE,
|
|
};
|
|
|
|
int bch2_dirent_rename(struct btree_trans *,
|
|
subvol_inum, struct bch_hash_info *,
|
|
subvol_inum, struct bch_hash_info *,
|
|
const struct qstr *, subvol_inum *, u64 *,
|
|
const struct qstr *, subvol_inum *, u64 *,
|
|
enum bch_rename_mode);
|
|
|
|
int bch2_dirent_lookup_trans(struct btree_trans *, struct btree_iter *,
|
|
subvol_inum, const struct bch_hash_info *,
|
|
const struct qstr *, subvol_inum *, unsigned);
|
|
u64 bch2_dirent_lookup(struct bch_fs *, subvol_inum,
|
|
const struct bch_hash_info *,
|
|
const struct qstr *, subvol_inum *);
|
|
|
|
int bch2_empty_dir_snapshot(struct btree_trans *, u64, u32, u32);
|
|
int bch2_empty_dir_trans(struct btree_trans *, subvol_inum);
|
|
int bch2_readdir(struct bch_fs *, subvol_inum, struct dir_context *);
|
|
|
|
#endif /* _BCACHEFS_DIRENT_H */
|