diff options
author | Sungjong Seo <sj1557.seo@samsung.com> | 2025-03-26 23:48:48 +0900 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2025-04-10 14:39:39 +0200 |
commit | 37c9875c178f1503af1864aadc29c42e7cb4374a (patch) | |
tree | dd12f08be805316dadee6f52e4c9bd871a8f6810 | |
parent | 49b0a6ab8e528a0c1c50e37cef9b9c7c121365f2 (diff) |
exfat: fix potential wrong error return from get_block
commit 59c30e31425833385e6644ad33151420e37eabe1 upstream.
If there is no error, get_block() should return 0. However, when bh_read()
returns 1, get_block() also returns 1 in the same manner.
Let's set err to 0, if there is no error from bh_read()
Fixes: 11a347fb6cef ("exfat: change to get file size from DataLength")
Cc: stable@vger.kernel.org
Signed-off-by: Sungjong Seo <sj1557.seo@samsung.com>
Reviewed-by: Yuezhang Mo <Yuezhang.Mo@sony.com>
Signed-off-by: Namjae Jeon <linkinjeon@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r-- | fs/exfat/inode.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/fs/exfat/inode.c b/fs/exfat/inode.c index 6e13c597e984..3801516ac507 100644 --- a/fs/exfat/inode.c +++ b/fs/exfat/inode.c @@ -391,6 +391,8 @@ static int exfat_get_block(struct inode *inode, sector_t iblock, /* Zero unwritten part of a block */ memset(bh_result->b_data + size, 0, bh_result->b_size - size); + + err = 0; } else { /* * The range has not been written, clear the mapped flag |