fat: add ratelimit to fat*_ent_bread()
authorOGAWA Hirofumi <hirofumi@mail.parknet.co.jp>
Fri, 29 Apr 2022 21:38:02 +0000 (14:38 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 9 Jun 2022 08:22:42 +0000 (10:22 +0200)
[ Upstream commit 183c3237c928109d2008c0456dff508baf692b20 ]

fat*_ent_bread() can be the cause of too many report on I/O error path.
So use fat_msg_ratelimit() instead.

Link: https://lkml.kernel.org/r/87bkxogfeq.fsf@mail.parknet.co.jp
Signed-off-by: OGAWA Hirofumi <hirofumi@mail.parknet.co.jp>
Reported-by: qianfan <qianfanguijin@163.com>
Tested-by: qianfan <qianfanguijin@163.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
fs/fat/fatent.c

index 978ac67..1db348f 100644 (file)
@@ -94,7 +94,8 @@ static int fat12_ent_bread(struct super_block *sb, struct fat_entry *fatent,
 err_brelse:
        brelse(bhs[0]);
 err:
-       fat_msg(sb, KERN_ERR, "FAT read failed (blocknr %llu)", (llu)blocknr);
+       fat_msg_ratelimit(sb, KERN_ERR, "FAT read failed (blocknr %llu)",
+                         (llu)blocknr);
        return -EIO;
 }
 
@@ -107,8 +108,8 @@ static int fat_ent_bread(struct super_block *sb, struct fat_entry *fatent,
        fatent->fat_inode = MSDOS_SB(sb)->fat_inode;
        fatent->bhs[0] = sb_bread(sb, blocknr);
        if (!fatent->bhs[0]) {
-               fat_msg(sb, KERN_ERR, "FAT read failed (blocknr %llu)",
-                      (llu)blocknr);
+               fat_msg_ratelimit(sb, KERN_ERR, "FAT read failed (blocknr %llu)",
+                                 (llu)blocknr);
                return -EIO;
        }
        fatent->nr_bhs = 1;