f2fs: support fault injection to f2fs_trylock_op()
authorChao Yu <chao@kernel.org>
Sun, 12 Dec 2021 09:17:51 +0000 (17:17 +0800)
committerJaegeuk Kim <jaegeuk@kernel.org>
Tue, 4 Jan 2022 21:20:56 +0000 (13:20 -0800)
f2fs: support fault injection for f2fs_trylock_op()

This patch supports to inject fault into f2fs_trylock_op().

Usage:
a) echo 65536 > /sys/fs/f2fs/<dev>/inject_type or
b) mount -o fault_type=65536 <dev> <mountpoint>

Signed-off-by: Chao Yu <chao@kernel.org>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
Documentation/filesystems/f2fs.rst
fs/f2fs/f2fs.h
fs/f2fs/super.c

index d7b84695f56aea48915c0cb6335d1dceb48e690c..4a2426f0485a994482f11244cf1b146966a5fcd0 100644 (file)
@@ -198,6 +198,7 @@ fault_type=%d                Support configuring fault injection type, should be
                         FAULT_WRITE_IO           0x000004000
                         FAULT_SLAB_ALLOC         0x000008000
                         FAULT_DQUOT_INIT         0x000010000
+                        FAULT_LOCK_OP            0x000020000
                         ===================      ===========
 mode=%s                         Control block allocation mode which supports "adaptive"
                         and "lfs". In "lfs" mode, there should be no random
index a9ed2fd3fffb923804a8a96f31bf86fc9d395272..8601d5e979d46e314f743a0bd2d23c655ddc6ed7 100644 (file)
@@ -56,6 +56,7 @@ enum {
        FAULT_WRITE_IO,
        FAULT_SLAB_ALLOC,
        FAULT_DQUOT_INIT,
+       FAULT_LOCK_OP,
        FAULT_MAX,
 };
 
@@ -2095,6 +2096,10 @@ static inline void f2fs_lock_op(struct f2fs_sb_info *sbi)
 
 static inline int f2fs_trylock_op(struct f2fs_sb_info *sbi)
 {
+       if (time_to_inject(sbi, FAULT_LOCK_OP)) {
+               f2fs_show_injection_info(sbi, FAULT_LOCK_OP);
+               return 0;
+       }
        return down_read_trylock(&sbi->cp_rwsem);
 }
 
index 9acd76ea09ca8accc5bbd55290ebc5b22b43221d..ca5783fa56d58c5f9e659324d4cb994a6f6333ca 100644 (file)
@@ -59,6 +59,7 @@ const char *f2fs_fault_name[FAULT_MAX] = {
        [FAULT_WRITE_IO]        = "write IO error",
        [FAULT_SLAB_ALLOC]      = "slab alloc",
        [FAULT_DQUOT_INIT]      = "dquot initialize",
+       [FAULT_LOCK_OP]         = "lock_op",
 };
 
 void f2fs_build_fault_attr(struct f2fs_sb_info *sbi, unsigned int rate,