| /* SPDX-License-Identifier: GPL-2.0 */ |
| #ifndef _BCACHEFS_INODE_FORMAT_H |
| #define _BCACHEFS_INODE_FORMAT_H |
| |
| #define BLOCKDEV_INODE_MAX 4096 |
| #define BCACHEFS_ROOT_INO 4096 |
| |
| struct bch_inode { |
| struct bch_val v; |
| |
| __le64 bi_hash_seed; |
| __le32 bi_flags; |
| __le16 bi_mode; |
| __u8 fields[]; |
| } __packed __aligned(8); |
| |
| struct bch_inode_v2 { |
| struct bch_val v; |
| |
| __le64 bi_journal_seq; |
| __le64 bi_hash_seed; |
| __le64 bi_flags; |
| __le16 bi_mode; |
| __u8 fields[]; |
| } __packed __aligned(8); |
| |
| struct bch_inode_v3 { |
| struct bch_val v; |
| |
| __le64 bi_journal_seq; |
| __le64 bi_hash_seed; |
| __le64 bi_flags; |
| __le64 bi_sectors; |
| __le64 bi_size; |
| __le64 bi_version; |
| __u8 fields[]; |
| } __packed __aligned(8); |
| |
| #define INODEv3_FIELDS_START_INITIAL 6 |
| #define INODEv3_FIELDS_START_CUR (offsetof(struct bch_inode_v3, fields) / sizeof(__u64)) |
| |
| struct bch_inode_generation { |
| struct bch_val v; |
| |
| __le32 bi_generation; |
| __le32 pad; |
| } __packed __aligned(8); |
| |
| /* |
| * bi_subvol and bi_parent_subvol are only set for subvolume roots: |
| */ |
| |
| #define BCH_INODE_FIELDS_v2() \ |
| x(bi_atime, 96) \ |
| x(bi_ctime, 96) \ |
| x(bi_mtime, 96) \ |
| x(bi_otime, 96) \ |
| x(bi_size, 64) \ |
| x(bi_sectors, 64) \ |
| x(bi_uid, 32) \ |
| x(bi_gid, 32) \ |
| x(bi_nlink, 32) \ |
| x(bi_generation, 32) \ |
| x(bi_dev, 32) \ |
| x(bi_data_checksum, 8) \ |
| x(bi_compression, 8) \ |
| x(bi_project, 32) \ |
| x(bi_background_compression, 8) \ |
| x(bi_data_replicas, 8) \ |
| x(bi_promote_target, 16) \ |
| x(bi_foreground_target, 16) \ |
| x(bi_background_target, 16) \ |
| x(bi_erasure_code, 16) \ |
| x(bi_fields_set, 16) \ |
| x(bi_dir, 64) \ |
| x(bi_dir_offset, 64) \ |
| x(bi_subvol, 32) \ |
| x(bi_parent_subvol, 32) |
| |
| #define BCH_INODE_FIELDS_v3() \ |
| x(bi_atime, 96) \ |
| x(bi_ctime, 96) \ |
| x(bi_mtime, 96) \ |
| x(bi_otime, 96) \ |
| x(bi_uid, 32) \ |
| x(bi_gid, 32) \ |
| x(bi_nlink, 32) \ |
| x(bi_generation, 32) \ |
| x(bi_dev, 32) \ |
| x(bi_data_checksum, 8) \ |
| x(bi_compression, 8) \ |
| x(bi_project, 32) \ |
| x(bi_background_compression, 8) \ |
| x(bi_data_replicas, 8) \ |
| x(bi_promote_target, 16) \ |
| x(bi_foreground_target, 16) \ |
| x(bi_background_target, 16) \ |
| x(bi_erasure_code, 16) \ |
| x(bi_fields_set, 16) \ |
| x(bi_dir, 64) \ |
| x(bi_dir_offset, 64) \ |
| x(bi_subvol, 32) \ |
| x(bi_parent_subvol, 32) \ |
| x(bi_nocow, 8) |
| |
| /* subset of BCH_INODE_FIELDS */ |
| #define BCH_INODE_OPTS() \ |
| x(data_checksum, 8) \ |
| x(compression, 8) \ |
| x(project, 32) \ |
| x(background_compression, 8) \ |
| x(data_replicas, 8) \ |
| x(promote_target, 16) \ |
| x(foreground_target, 16) \ |
| x(background_target, 16) \ |
| x(erasure_code, 16) \ |
| x(nocow, 8) |
| |
| enum inode_opt_id { |
| #define x(name, ...) \ |
| Inode_opt_##name, |
| BCH_INODE_OPTS() |
| #undef x |
| Inode_opt_nr, |
| }; |
| |
| #define BCH_INODE_FLAGS() \ |
| x(sync, 0) \ |
| x(immutable, 1) \ |
| x(append, 2) \ |
| x(nodump, 3) \ |
| x(noatime, 4) \ |
| x(i_size_dirty, 5) \ |
| x(i_sectors_dirty, 6) \ |
| x(unlinked, 7) \ |
| x(backptr_untrusted, 8) |
| |
| /* bits 20+ reserved for packed fields below: */ |
| |
| enum bch_inode_flags { |
| #define x(t, n) BCH_INODE_##t = 1U << n, |
| BCH_INODE_FLAGS() |
| #undef x |
| }; |
| |
| enum __bch_inode_flags { |
| #define x(t, n) __BCH_INODE_##t = n, |
| BCH_INODE_FLAGS() |
| #undef x |
| }; |
| |
| LE32_BITMASK(INODE_STR_HASH, struct bch_inode, bi_flags, 20, 24); |
| LE32_BITMASK(INODE_NR_FIELDS, struct bch_inode, bi_flags, 24, 31); |
| LE32_BITMASK(INODE_NEW_VARINT, struct bch_inode, bi_flags, 31, 32); |
| |
| LE64_BITMASK(INODEv2_STR_HASH, struct bch_inode_v2, bi_flags, 20, 24); |
| LE64_BITMASK(INODEv2_NR_FIELDS, struct bch_inode_v2, bi_flags, 24, 31); |
| |
| LE64_BITMASK(INODEv3_STR_HASH, struct bch_inode_v3, bi_flags, 20, 24); |
| LE64_BITMASK(INODEv3_NR_FIELDS, struct bch_inode_v3, bi_flags, 24, 31); |
| |
| LE64_BITMASK(INODEv3_FIELDS_START, |
| struct bch_inode_v3, bi_flags, 31, 36); |
| LE64_BITMASK(INODEv3_MODE, struct bch_inode_v3, bi_flags, 36, 52); |
| |
| #endif /* _BCACHEFS_INODE_FORMAT_H */ |