Skip to content

Commit 9f3fb90

Browse files
ebiggersgregkh
authored andcommitted
fs/minix: remove expected error message in block_to_path()
[ Upstream commit f666f9f ] When truncating a file to a size within the last allowed logical block, block_to_path() is called with the *next* block. This exceeds the limit, causing the "block %ld too big" error message to be printed. This case isn't actually an error; there are just no more blocks past that point. So, remove this error message. Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2") Signed-off-by: Eric Biggers <ebiggers@google.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Cc: Alexander Viro <viro@zeniv.linux.org.uk> Cc: Qiujun Huang <anenbupt@gmail.com> Link: http://lkml.kernel.org/r/20200628060846.682158-7-ebiggers@kernel.org Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> Signed-off-by: Sasha Levin <sashal@kernel.org>
1 parent c7ac366 commit 9f3fb90

2 files changed

Lines changed: 12 additions & 12 deletions

File tree

fs/minix/itree_v1.c

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -29,12 +29,12 @@ static int block_to_path(struct inode * inode, long block, int offsets[DEPTH])
2929
if (block < 0) {
3030
printk("MINIX-fs: block_to_path: block %ld < 0 on dev %pg\n",
3131
block, inode->i_sb->s_bdev);
32-
} else if ((u64)block * BLOCK_SIZE >= inode->i_sb->s_maxbytes) {
33-
if (printk_ratelimit())
34-
printk("MINIX-fs: block_to_path: "
35-
"block %ld too big on dev %pg\n",
36-
block, inode->i_sb->s_bdev);
37-
} else if (block < 7) {
32+
return 0;
33+
}
34+
if ((u64)block * BLOCK_SIZE >= inode->i_sb->s_maxbytes)
35+
return 0;
36+
37+
if (block < 7) {
3838
offsets[n++] = block;
3939
} else if ((block -= 7) < 512) {
4040
offsets[n++] = 7;

fs/minix/itree_v2.c

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -32,12 +32,12 @@ static int block_to_path(struct inode * inode, long block, int offsets[DEPTH])
3232
if (block < 0) {
3333
printk("MINIX-fs: block_to_path: block %ld < 0 on dev %pg\n",
3434
block, sb->s_bdev);
35-
} else if ((u64)block * (u64)sb->s_blocksize >= sb->s_maxbytes) {
36-
if (printk_ratelimit())
37-
printk("MINIX-fs: block_to_path: "
38-
"block %ld too big on dev %pg\n",
39-
block, sb->s_bdev);
40-
} else if (block < DIRCOUNT) {
35+
return 0;
36+
}
37+
if ((u64)block * (u64)sb->s_blocksize >= sb->s_maxbytes)
38+
return 0;
39+
40+
if (block < DIRCOUNT) {
4141
offsets[n++] = block;
4242
} else if ((block -= DIRCOUNT) < INDIRCOUNT(sb)) {
4343
offsets[n++] = DIRCOUNT;

0 commit comments

Comments
 (0)