diff options
-rw-r--r-- | fs/f2fs/f2fs.h | 9 | ||||
-rw-r--r-- | fs/f2fs/super.c | 1 |
2 files changed, 10 insertions, 0 deletions
diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h index cf03c57d0feb..d550a95d30f1 100644 --- a/fs/f2fs/f2fs.h +++ b/fs/f2fs/f2fs.h | |||
@@ -40,6 +40,7 @@ | |||
40 | #ifdef CONFIG_F2FS_FAULT_INJECTION | 40 | #ifdef CONFIG_F2FS_FAULT_INJECTION |
41 | enum { | 41 | enum { |
42 | FAULT_KMALLOC, | 42 | FAULT_KMALLOC, |
43 | FAULT_PAGE_ALLOC, | ||
43 | FAULT_MAX, | 44 | FAULT_MAX, |
44 | }; | 45 | }; |
45 | 46 | ||
@@ -1296,6 +1297,14 @@ static inline unsigned int valid_inode_count(struct f2fs_sb_info *sbi) | |||
1296 | static inline struct page *f2fs_grab_cache_page(struct address_space *mapping, | 1297 | static inline struct page *f2fs_grab_cache_page(struct address_space *mapping, |
1297 | pgoff_t index, bool for_write) | 1298 | pgoff_t index, bool for_write) |
1298 | { | 1299 | { |
1300 | #ifdef CONFIG_F2FS_FAULT_INJECTION | ||
1301 | struct page *page = find_lock_page(mapping, index); | ||
1302 | if (page) | ||
1303 | return page; | ||
1304 | |||
1305 | if (time_to_inject(FAULT_PAGE_ALLOC)) | ||
1306 | return NULL; | ||
1307 | #endif | ||
1299 | if (!for_write) | 1308 | if (!for_write) |
1300 | return grab_cache_page(mapping, index); | 1309 | return grab_cache_page(mapping, index); |
1301 | return grab_cache_page_write_begin(mapping, index, AOP_FLAG_NOFS); | 1310 | return grab_cache_page_write_begin(mapping, index, AOP_FLAG_NOFS); |
diff --git a/fs/f2fs/super.c b/fs/f2fs/super.c index 9a56f544da3e..986d0da84e01 100644 --- a/fs/f2fs/super.c +++ b/fs/f2fs/super.c | |||
@@ -45,6 +45,7 @@ atomic_t f2fs_ops; | |||
45 | 45 | ||
46 | char *fault_name[FAULT_MAX] = { | 46 | char *fault_name[FAULT_MAX] = { |
47 | [FAULT_KMALLOC] = "kmalloc", | 47 | [FAULT_KMALLOC] = "kmalloc", |
48 | [FAULT_PAGE_ALLOC] = "page alloc", | ||
48 | }; | 49 | }; |
49 | #endif | 50 | #endif |
50 | 51 | ||