CVE-2025-38260 Information
Description
In the Linux kernel the following vulnerability has been resolved:
btrfs: handle csum tree error with rescue=ibadroots correctly
[BUG] There is syzbot based reproducer that can crash the kernel with the following call trace: (With some debug output added)
DEBUG: rescue=ibadroots parsed
BTRFS: device fsid 14d642db-7b15-43e4-81e6-4b8fac6a25f8 devid 1 transid 8 /dev/loop0 (7:0) scanned by repro (1010)
BTRFS info (device loop0): first mount of filesystem 14d642db-7b15-43e4-81e6-4b8fac6a25f8
BTRFS info (device loop0): using blake2b (blake2b-256-generic) checksum algorithm
BTRFS info (device loop0): using free-space-tree
BTRFS warning (device loop0): checksum verify failed on logical 5312512 mirror 1 wanted 0xb043382657aede36608fd3386d6b001692ff406164733d94e2d9a180412c6003 found 0x810ceb2bacb7f0f9eb2bf3b2b15c02af867cb35ad450898169f3b1f0bd818651 level 0
DEBUG: read tree root path failed for tree csum ret=-5
BTRFS warning (device loop0): checksum verify failed on logical 5328896 mirror 1 wanted 0x51be4e8b303da58e6340226815b70e3a93592dac3f30dd510c7517454de8567a found 0x51be4e8b303da58e634022a315b70e3a93592dac3f30dd510c7517454de8567a level 0
BTRFS warning (device loop0): checksum verify failed on logical 5292032 mirror 1 wanted 0x1924ccd683be9efc2fa98582ef58760e3848e9043db8649ee382681e220cdee4 found 0x0cb6184f6e8799d9f8cb335dccd1d1832da1071d12290dab3b85b587ecacca6e level 0
process ‘repro’ launched ‘./file2’ with NULL argv: empty string added
DEBUG: no csum root idatacsums=0 ibadroots=134217728
Oops: general protection fault probably for non-canonical address 0xdffffc0000000041: 0000 [1] SMP KASAN NOPTI
KASAN: null-ptr-deref in range [0x0000000000000208-0x000000000000020f]
CPU: 5 UID: 0 PID: 1010 Comm: repro Tainted: G OE 6.15.0-custom+ 249 PREEMPT(full)
Hardware name: QEMU Standard PC (Q35 + ICH9 2009) BIOS unknown 02/02/2022
RIP: 0010:btrfs_lookup_csum+0x93/0x3d0 [btrfs]
Call Trace:
[CAUSE] Firstly the fs has a corrupted csum tree root thus to mount the fs we have to go orescue=ibadroots\ mount option.
Normally with that mount option a bad csum tree root should set BTRFS_FS_STATE_NO_DATA_CSUMS flag so that any future data read will ignore csum search.
But in this particular case we have the following call trace that caused NULL csum root but not setting BTRFS_FS_STATE_NO_DATA_CSUMS:
load_global_roots_objectid():
ret = btrfs_search_slot();
/ Succeeded /
btrfs_item_key_to_cpu()
found = true;
/ We found the root item for csum tree. /
root = read_tree_root_path();
if (IS_ERR(root))
if (!btrfs_test_opt(fs_info IGNOREBADROOTS))
/
Since we have rescue=ibadroots mount option
@ret is still 0.
/
break;
if (!found || ret)
/ @found is true @ret is 0 error handling for csum
tree is skipped.
/
This means we completely skipped to set BTRFS_FS_STATE_NO_DATA_CSUMS if the csum tree is corrupted which results unexpected later csum lookup.
[FIX] If read_tree_root_path() failed always populate @ret to the error number.
As at the end of the function we need @ret to determine if we need to do the extra error handling for csum tree.
Reference
https://git.kernel.org/stable/c/3f5c4a996f8f4fecd24a3eb344a307c50af895c2 https://git.kernel.org/stable/c/547e836661554dcfa15c212a3821664e85b4191a https://git.kernel.org/stable/c/bbe9231fe611a54a447962494472f604419bad59 https://git.kernel.org/stable/c/f8ce11903211542a61f05c02caedd2edfb4256b8 https://git.kernel.org/stable/c/fc97a116dc4929905538bc0bd3af7faa51192957
Related CNNVD
CNNVD-202507-1302 (Published: 2025-07-09)
Share on: