xref: /kernel/linux/linux-6.6/fs/btrfs/inode-item.h (revision 62306a36)
1/* SPDX-License-Identifier: GPL-2.0 */
2
3#ifndef BTRFS_INODE_ITEM_H
4#define BTRFS_INODE_ITEM_H
5
6#include <linux/types.h>
7
8struct btrfs_trans_handle;
9struct btrfs_root;
10struct btrfs_path;
11struct btrfs_key;
12struct btrfs_inode_extref;
13struct btrfs_inode;
14struct extent_buffer;
15
16/*
17 * Return this if we need to call truncate_block for the last bit of the
18 * truncate.
19 */
20#define BTRFS_NEED_TRUNCATE_BLOCK		1
21
22struct btrfs_truncate_control {
23	/*
24	 * IN: the inode we're operating on, this can be NULL if
25	 * ->clear_extent_range is false.
26	 */
27	struct btrfs_inode *inode;
28
29	/* IN: the size we're truncating to. */
30	u64 new_size;
31
32	/* OUT: the number of extents truncated. */
33	u64 extents_found;
34
35	/* OUT: the last size we truncated this inode to. */
36	u64 last_size;
37
38	/* OUT: the number of bytes to sub from this inode. */
39	u64 sub_bytes;
40
41	/* IN: the ino we are truncating. */
42	u64 ino;
43
44	/*
45	 * IN: minimum key type to remove.  All key types with this type are
46	 * removed only if their offset >= new_size.
47	 */
48	u32 min_type;
49
50	/*
51	 * IN: true if we don't want to do extent reference updates for any file
52	 * extents we drop.
53	 */
54	bool skip_ref_updates;
55
56	/*
57	 * IN: true if we need to clear the file extent range for the inode as
58	 * we drop the file extent items.
59	 */
60	bool clear_extent_range;
61};
62
63/*
64 * btrfs_inode_item stores flags in a u64, btrfs_inode stores them in two
65 * separate u32s. These two functions convert between the two representations.
66 */
67static inline u64 btrfs_inode_combine_flags(u32 flags, u32 ro_flags)
68{
69	return (flags | ((u64)ro_flags << 32));
70}
71
72static inline void btrfs_inode_split_flags(u64 inode_item_flags,
73					   u32 *flags, u32 *ro_flags)
74{
75	*flags = (u32)inode_item_flags;
76	*ro_flags = (u32)(inode_item_flags >> 32);
77}
78
79int btrfs_truncate_inode_items(struct btrfs_trans_handle *trans,
80			       struct btrfs_root *root,
81			       struct btrfs_truncate_control *control);
82int btrfs_insert_inode_ref(struct btrfs_trans_handle *trans,
83			   struct btrfs_root *root, const struct fscrypt_str *name,
84			   u64 inode_objectid, u64 ref_objectid, u64 index);
85int btrfs_del_inode_ref(struct btrfs_trans_handle *trans,
86			struct btrfs_root *root, const struct fscrypt_str *name,
87			u64 inode_objectid, u64 ref_objectid, u64 *index);
88int btrfs_insert_empty_inode(struct btrfs_trans_handle *trans,
89			     struct btrfs_root *root,
90			     struct btrfs_path *path, u64 objectid);
91int btrfs_lookup_inode(struct btrfs_trans_handle *trans,
92		       struct btrfs_root *root, struct btrfs_path *path,
93		       struct btrfs_key *location, int mod);
94
95struct btrfs_inode_extref *btrfs_lookup_inode_extref(
96			  struct btrfs_trans_handle *trans,
97			  struct btrfs_root *root,
98			  struct btrfs_path *path,
99			  const struct fscrypt_str *name,
100			  u64 inode_objectid, u64 ref_objectid, int ins_len,
101			  int cow);
102
103struct btrfs_inode_ref *btrfs_find_name_in_backref(struct extent_buffer *leaf,
104						   int slot,
105						   const struct fscrypt_str *name);
106struct btrfs_inode_extref *btrfs_find_name_in_ext_backref(
107		struct extent_buffer *leaf, int slot, u64 ref_objectid,
108		const struct fscrypt_str *name);
109
110#endif
111