Re: [PATCH v2] loop: don't change loop device under exclusive opener in loop_set_status
From: Jens Axboe
Date: Tue Jan 06 2026 - 07:31:22 EST
On 1/6/26 5:08 AM, Jan Kara wrote:
> On Wed 17-12-25 14:00:40, Raphael Pinsonneault-Thibeault wrote:
>> loop_set_status() is allowed to change the loop device while there
>> are other openers of the device, even exclusive ones.
>>
>> In this case, it causes a KASAN: slab-out-of-bounds Read in
>> ext4_search_dir(), since when looking for an entry in an inlined
>> directory, e_value_offs is changed underneath the filesystem by
>> loop_set_status().
>>
>> Fix the problem by forbidding loop_set_status() from modifying the loop
>> device while there are exclusive openers of the device. This is similar
>> to the fix in loop_configure() by commit 33ec3e53e7b1 ("loop: Don't
>> change loop device under exclusive opener") alongside commit ecbe6bc0003b
>> ("block: use bd_prepare_to_claim directly in the loop driver").
>>
>> Reported-by: syzbot+3ee481e21fd75e14c397@xxxxxxxxxxxxxxxxxxxxxxxxx
>> Closes: https://syzkaller.appspot.com/bug?extid=3ee481e21fd75e14c397
>> Tested-by: syzbot+3ee481e21fd75e14c397@xxxxxxxxxxxxxxxxxxxxxxxxx
>> Tested-by: Yongpeng Yang <yangyongpeng@xxxxxxxxxx>
>> Signed-off-by: Raphael Pinsonneault-Thibeault <rpthibeault@xxxxxxxxx>
>> Reviewed-by: Jan Kara <jack@xxxxxxx>
>
> Jens, ping?
Now applied. Heads up in general, don't nest v2 or later inside the
original thread. It just makes emails get lost, as it appears part
of the original discussion.
--
Jens Axboe