19
19
#include "node.h"
20
20
#include <trace/events/f2fs.h>
21
21
22
- bool sanity_check_extent_cache (struct inode * inode )
22
+ bool sanity_check_extent_cache (struct inode * inode , struct page * ipage )
23
23
{
24
24
struct f2fs_sb_info * sbi = F2FS_I_SB (inode );
25
- struct f2fs_inode_info * fi = F2FS_I (inode );
26
- struct extent_tree * et = fi -> extent_tree [EX_READ ];
27
- struct extent_info * ei ;
28
-
29
- if (!et )
30
- return true;
25
+ struct f2fs_extent * i_ext = & F2FS_INODE (ipage )-> i_ext ;
26
+ struct extent_info ei ;
31
27
32
- ei = & et -> largest ;
33
- if (!ei -> len )
34
- return true;
28
+ get_read_extent_info (& ei , i_ext );
35
29
36
- /* Let's drop, if checkpoint got corrupted. */
37
- if (is_set_ckpt_flags (sbi , CP_ERROR_FLAG )) {
38
- ei -> len = 0 ;
39
- et -> largest_updated = true;
30
+ if (!ei .len )
40
31
return true;
41
- }
42
32
43
- if (!f2fs_is_valid_blkaddr (sbi , ei -> blk , DATA_GENERIC_ENHANCE ) ||
44
- !f2fs_is_valid_blkaddr (sbi , ei -> blk + ei -> len - 1 ,
33
+ if (!f2fs_is_valid_blkaddr (sbi , ei . blk , DATA_GENERIC_ENHANCE ) ||
34
+ !f2fs_is_valid_blkaddr (sbi , ei . blk + ei . len - 1 ,
45
35
DATA_GENERIC_ENHANCE )) {
46
36
f2fs_warn (sbi , "%s: inode (ino=%lx) extent info [%u, %u, %u] is incorrect, run fsck to fix" ,
47
37
__func__ , inode -> i_ino ,
48
- ei -> blk , ei -> fofs , ei -> len );
38
+ ei . blk , ei . fofs , ei . len );
49
39
return false;
50
40
}
51
41
return true;
@@ -394,24 +384,22 @@ void f2fs_init_read_extent_tree(struct inode *inode, struct page *ipage)
394
384
395
385
if (!__may_extent_tree (inode , EX_READ )) {
396
386
/* drop largest read extent */
397
- if (i_ext && i_ext -> len ) {
387
+ if (i_ext -> len ) {
398
388
f2fs_wait_on_page_writeback (ipage , NODE , true, true);
399
389
i_ext -> len = 0 ;
400
390
set_page_dirty (ipage );
401
391
}
402
- goto out ;
392
+ set_inode_flag (inode , FI_NO_EXTENT );
393
+ return ;
403
394
}
404
395
405
396
et = __grab_extent_tree (inode , EX_READ );
406
397
407
- if (!i_ext || !i_ext -> len )
408
- goto out ;
409
-
410
398
get_read_extent_info (& ei , i_ext );
411
399
412
400
write_lock (& et -> lock );
413
- if (atomic_read (& et -> node_cnt ))
414
- goto unlock_out ;
401
+ if (atomic_read (& et -> node_cnt ) || ! ei . len )
402
+ goto skip ;
415
403
416
404
en = __attach_extent_node (sbi , et , & ei , NULL ,
417
405
& et -> root .rb_root .rb_node , true);
@@ -423,11 +411,13 @@ void f2fs_init_read_extent_tree(struct inode *inode, struct page *ipage)
423
411
list_add_tail (& en -> list , & eti -> extent_list );
424
412
spin_unlock (& eti -> extent_lock );
425
413
}
426
- unlock_out :
414
+ skip :
415
+ /* Let's drop, if checkpoint got corrupted. */
416
+ if (f2fs_cp_error (sbi )) {
417
+ et -> largest .len = 0 ;
418
+ et -> largest_updated = true;
419
+ }
427
420
write_unlock (& et -> lock );
428
- out :
429
- if (!F2FS_I (inode )-> extent_tree [EX_READ ])
430
- set_inode_flag (inode , FI_NO_EXTENT );
431
421
}
432
422
433
423
void f2fs_init_age_extent_tree (struct inode * inode )
0 commit comments