Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

jfs: add check read-only before txBeginAnon() call

Added a read-only check before calling `txBeginAnon` in `extAlloc`
and `extRecord`. This prevents modification attempts on a read-only
mounted filesystem, avoiding potential errors or crashes.

Call trace:
txBeginAnon+0xac/0x154
extAlloc+0xe8/0xdec fs/jfs/jfs_extent.c:78
jfs_get_block+0x340/0xb98 fs/jfs/inode.c:248
__block_write_begin_int+0x580/0x166c fs/buffer.c:2128
__block_write_begin fs/buffer.c:2177 [inline]
block_write_begin+0x98/0x11c fs/buffer.c:2236
jfs_write_begin+0x44/0x88 fs/jfs/inode.c:299

Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2")
Reported-by: syzbot+4e89b5368baba8324e07@syzkaller.appspotmail.com
Link: https://syzkaller.appspot.com/bug?extid=4e89b5368baba8324e07
Signed-off-by: Vasiliy Kovalev <kovalev@altlinux.org>
Signed-off-by: Dave Kleikamp <dave.kleikamp@oracle.com>

authored by

Vasiliy Kovalev and committed by
Dave Kleikamp
0176e697 8c3f9a70

+10
+10
fs/jfs/jfs_extent.c
··· 74 74 int rc; 75 75 int xflag; 76 76 77 + if (isReadOnly(ip)) { 78 + jfs_error(ip->i_sb, "read-only filesystem\n"); 79 + return -EIO; 80 + } 81 + 77 82 /* This blocks if we are low on resources */ 78 83 txBeginAnon(ip->i_sb); 79 84 ··· 257 252 int extRecord(struct inode *ip, xad_t * xp) 258 253 { 259 254 int rc; 255 + 256 + if (isReadOnly(ip)) { 257 + jfs_error(ip->i_sb, "read-only filesystem\n"); 258 + return -EIO; 259 + } 260 260 261 261 txBeginAnon(ip->i_sb); 262 262