1 /* SPDX-License-Identifier: GPL-2.0 */
3 #ifndef BTRFS_INODE_ITEM_H
4 #define BTRFS_INODE_ITEM_H
6 #include <linux/types.h>
7 #include <linux/crc32c.h>
11 struct btrfs_trans_handle;
15 struct btrfs_inode_extref;
17 struct btrfs_truncate_control;
20 * Return this if we need to call truncate_block for the last bit of the
23 #define BTRFS_NEED_TRUNCATE_BLOCK 1
25 struct btrfs_truncate_control {
27 * IN: the inode we're operating on, this can be NULL if
28 * ->clear_extent_range is false.
30 struct btrfs_inode *inode;
32 /* IN: the size we're truncating to. */
35 /* OUT: the number of extents truncated. */
38 /* OUT: the last size we truncated this inode to. */
41 /* OUT: the number of bytes to sub from this inode. */
44 /* IN: the ino we are truncating. */
48 * IN: minimum key type to remove. All key types with this type are
49 * removed only if their offset >= new_size.
54 * IN: true if we don't want to do extent reference updates for any file
57 bool skip_ref_updates;
60 * IN: true if we need to clear the file extent range for the inode as
61 * we drop the file extent items.
63 bool clear_extent_range;
67 * btrfs_inode_item stores flags in a u64, btrfs_inode stores them in two
68 * separate u32s. These two functions convert between the two representations.
70 static inline u64 btrfs_inode_combine_flags(u32 flags, u32 ro_flags)
72 return (flags | ((u64)ro_flags << 32));
75 static inline void btrfs_inode_split_flags(u64 inode_item_flags,
76 u32 *flags, u32 *ro_flags)
78 *flags = (u32)inode_item_flags;
79 *ro_flags = (u32)(inode_item_flags >> 32);
82 /* Figure the key offset of an extended inode ref. */
83 static inline u64 btrfs_extref_hash(u64 parent_objectid, const char *name, int len)
85 return (u64)crc32c(parent_objectid, name, len);
88 int btrfs_truncate_inode_items(struct btrfs_trans_handle *trans,
89 struct btrfs_root *root,
90 struct btrfs_truncate_control *control);
91 int btrfs_insert_inode_ref(struct btrfs_trans_handle *trans,
92 struct btrfs_root *root, const struct fscrypt_str *name,
93 u64 inode_objectid, u64 ref_objectid, u64 index);
94 int btrfs_del_inode_ref(struct btrfs_trans_handle *trans,
95 struct btrfs_root *root, const struct fscrypt_str *name,
96 u64 inode_objectid, u64 ref_objectid, u64 *index);
97 int btrfs_insert_empty_inode(struct btrfs_trans_handle *trans,
98 struct btrfs_root *root,
99 struct btrfs_path *path, u64 objectid);
100 int btrfs_lookup_inode(struct btrfs_trans_handle *trans,
101 struct btrfs_root *root, struct btrfs_path *path,
102 struct btrfs_key *location, int mod);
104 struct btrfs_inode_extref *btrfs_lookup_inode_extref(
105 struct btrfs_trans_handle *trans,
106 struct btrfs_root *root,
107 struct btrfs_path *path,
108 const struct fscrypt_str *name,
109 u64 inode_objectid, u64 ref_objectid, int ins_len,
112 struct btrfs_inode_ref *btrfs_find_name_in_backref(const struct extent_buffer *leaf,
114 const struct fscrypt_str *name);
115 struct btrfs_inode_extref *btrfs_find_name_in_ext_backref(
116 const struct extent_buffer *leaf, int slot, u64 ref_objectid,
117 const struct fscrypt_str *name);