1
2
3
4
5
6#ifndef BTRFS_INODE_H
7#define BTRFS_INODE_H
8
9#include <linux/hash.h>
10#include <linux/refcount.h>
11#include "extent_map.h"
12#include "extent_io.h"
13#include "ordered-data.h"
14#include "delayed-inode.h"
15
16
17
18
19
20
21
22
23enum {
24 BTRFS_INODE_FLUSH_ON_CLOSE,
25 BTRFS_INODE_DUMMY,
26 BTRFS_INODE_IN_DEFRAG,
27 BTRFS_INODE_HAS_ASYNC_EXTENT,
28
29
30
31
32
33 BTRFS_INODE_NEEDS_FULL_SYNC,
34 BTRFS_INODE_COPY_EVERYTHING,
35 BTRFS_INODE_IN_DELALLOC_LIST,
36 BTRFS_INODE_HAS_PROPS,
37 BTRFS_INODE_SNAPSHOT_FLUSH,
38
39
40
41
42
43
44 BTRFS_INODE_NO_XATTRS,
45
46
47
48
49
50
51
52
53 BTRFS_INODE_NO_DELALLOC_FLUSH,
54};
55
56
57struct btrfs_inode {
58
59 struct btrfs_root *root;
60
61
62
63
64 struct btrfs_key location;
65
66
67
68
69
70
71
72 spinlock_t lock;
73
74
75 struct extent_map_tree extent_tree;
76
77
78 struct extent_io_tree io_tree;
79
80
81
82
83 struct extent_io_tree io_failure_tree;
84
85
86
87
88
89 struct extent_io_tree file_extent_tree;
90
91
92 struct mutex log_mutex;
93
94
95 struct btrfs_ordered_inode_tree ordered_tree;
96
97
98
99
100
101 struct list_head delalloc_inodes;
102
103
104 struct rb_node rb_node;
105
106 unsigned long runtime_flags;
107
108
109 atomic_t sync_writers;
110
111
112
113
114 u64 generation;
115
116
117
118
119 u64 last_trans;
120
121
122
123
124 u64 logged_trans;
125
126
127
128
129 int last_sub_trans;
130
131
132 int last_log_commit;
133
134
135
136
137 u64 delalloc_bytes;
138
139
140
141
142
143
144 u64 new_delalloc_bytes;
145
146
147
148
149
150 u64 defrag_bytes;
151
152
153
154
155
156
157 u64 disk_i_size;
158
159
160
161
162
163 u64 index_cnt;
164
165
166 u64 dir_index;
167
168
169
170
171
172
173 u64 last_unlink_trans;
174
175
176
177
178
179
180
181
182
183
184 u64 last_reflink_trans;
185
186
187
188
189
190 u64 csum_bytes;
191
192
193 u32 flags;
194
195
196
197
198
199
200
201 unsigned outstanding_extents;
202
203 struct btrfs_block_rsv block_rsv;
204
205
206
207
208 unsigned prop_compress;
209
210
211
212
213 unsigned defrag_compress;
214
215 struct btrfs_delayed_node *delayed_node;
216
217
218 struct timespec64 i_otime;
219
220
221 struct list_head delayed_iput;
222
223 struct rw_semaphore i_mmap_lock;
224 struct inode vfs_inode;
225};
226
227static inline u32 btrfs_inode_sectorsize(const struct btrfs_inode *inode)
228{
229 return inode->root->fs_info->sectorsize;
230}
231
232static inline struct btrfs_inode *BTRFS_I(const struct inode *inode)
233{
234 return container_of(inode, struct btrfs_inode, vfs_inode);
235}
236
237static inline unsigned long btrfs_inode_hash(u64 objectid,
238 const struct btrfs_root *root)
239{
240 u64 h = objectid ^ (root->root_key.objectid * GOLDEN_RATIO_PRIME);
241
242#if BITS_PER_LONG == 32
243 h = (h >> 32) ^ (h & 0xffffffff);
244#endif
245
246 return (unsigned long)h;
247}
248
249static inline void btrfs_insert_inode_hash(struct inode *inode)
250{
251 unsigned long h = btrfs_inode_hash(inode->i_ino, BTRFS_I(inode)->root);
252
253 __insert_inode_hash(inode, h);
254}
255
256static inline u64 btrfs_ino(const struct btrfs_inode *inode)
257{
258 u64 ino = inode->location.objectid;
259
260
261
262
263
264 if (!ino || inode->location.type == BTRFS_ROOT_ITEM_KEY)
265 ino = inode->vfs_inode.i_ino;
266 return ino;
267}
268
269static inline void btrfs_i_size_write(struct btrfs_inode *inode, u64 size)
270{
271 i_size_write(&inode->vfs_inode, size);
272 inode->disk_i_size = size;
273}
274
275static inline bool btrfs_is_free_space_inode(struct btrfs_inode *inode)
276{
277 struct btrfs_root *root = inode->root;
278
279 if (root == root->fs_info->tree_root &&
280 btrfs_ino(inode) != BTRFS_BTREE_INODE_OBJECTID)
281 return true;
282 if (inode->location.objectid == BTRFS_FREE_INO_OBJECTID)
283 return true;
284 return false;
285}
286
287static inline bool is_data_inode(struct inode *inode)
288{
289 return btrfs_ino(BTRFS_I(inode)) != BTRFS_BTREE_INODE_OBJECTID;
290}
291
292static inline void btrfs_mod_outstanding_extents(struct btrfs_inode *inode,
293 int mod)
294{
295 lockdep_assert_held(&inode->lock);
296 inode->outstanding_extents += mod;
297 if (btrfs_is_free_space_inode(inode))
298 return;
299 trace_btrfs_inode_mod_outstanding_extents(inode->root, btrfs_ino(inode),
300 mod);
301}
302
303
304
305
306
307
308
309
310
311static inline void btrfs_set_inode_last_sub_trans(struct btrfs_inode *inode)
312{
313 spin_lock(&inode->lock);
314 inode->last_sub_trans = inode->root->log_transid;
315 spin_unlock(&inode->lock);
316}
317
318static inline bool btrfs_inode_in_log(struct btrfs_inode *inode, u64 generation)
319{
320 bool ret = false;
321
322 spin_lock(&inode->lock);
323 if (inode->logged_trans == generation &&
324 inode->last_sub_trans <= inode->last_log_commit &&
325 inode->last_sub_trans <= inode->root->last_log_commit)
326 ret = true;
327 spin_unlock(&inode->lock);
328 return ret;
329}
330
331struct btrfs_dio_private {
332 struct inode *inode;
333 u64 logical_offset;
334 u64 disk_bytenr;
335
336 u32 bytes;
337
338
339
340
341
342 refcount_t refs;
343
344
345 struct bio *dio_bio;
346
347
348 u8 csums[];
349};
350
351
352#define CSUM_FMT "0x%*phN"
353#define CSUM_FMT_VALUE(size, bytes) size, bytes
354
355static inline void btrfs_print_data_csum_error(struct btrfs_inode *inode,
356 u64 logical_start, u8 *csum, u8 *csum_expected, int mirror_num)
357{
358 struct btrfs_root *root = inode->root;
359 const u32 csum_size = root->fs_info->csum_size;
360
361
362 if (root->root_key.objectid >= BTRFS_LAST_FREE_OBJECTID)
363 btrfs_warn_rl(root->fs_info,
364"csum failed root %lld ino %lld off %llu csum " CSUM_FMT " expected csum " CSUM_FMT " mirror %d",
365 root->root_key.objectid, btrfs_ino(inode),
366 logical_start,
367 CSUM_FMT_VALUE(csum_size, csum),
368 CSUM_FMT_VALUE(csum_size, csum_expected),
369 mirror_num);
370 else
371 btrfs_warn_rl(root->fs_info,
372"csum failed root %llu ino %llu off %llu csum " CSUM_FMT " expected csum " CSUM_FMT " mirror %d",
373 root->root_key.objectid, btrfs_ino(inode),
374 logical_start,
375 CSUM_FMT_VALUE(csum_size, csum),
376 CSUM_FMT_VALUE(csum_size, csum_expected),
377 mirror_num);
378}
379
380#endif
381