]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
fs/ntfs3: Additional check in ni_clear()
authorKonstantin Komarov <almaz.alexandrovich@paragon-software.com>
Mon, 9 Sep 2024 12:39:10 +0000 (15:39 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 8 Nov 2024 15:25:53 +0000 (16:25 +0100)
[ Upstream commit d178944db36b3369b78a08ba520de109b89bf2a9 ]

Checking of NTFS_FLAGS_LOG_REPLAYING added to prevent access to
uninitialized bitmap during replay process.

Reported-by: syzbot+3bfd2cc059ab93efcdb4@syzkaller.appspotmail.com
Signed-off-by: Konstantin Komarov <almaz.alexandrovich@paragon-software.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
fs/ntfs3/frecord.c

index 7a1f57dc58dfcacf5b34d395b3ce11ec5ddefb9c..a74bbfec8e3ac5dec0177f1e232813f4ff677cc4 100644 (file)
@@ -101,7 +101,9 @@ void ni_clear(struct ntfs_inode *ni)
 {
        struct rb_node *node;
 
-       if (!ni->vfs_inode.i_nlink && ni->mi.mrec && is_rec_inuse(ni->mi.mrec))
+       if (!ni->vfs_inode.i_nlink && ni->mi.mrec &&
+           is_rec_inuse(ni->mi.mrec) &&
+           !(ni->mi.sbi->flags & NTFS_FLAGS_LOG_REPLAYING))
                ni_delete_all(ni);
 
        al_destroy(ni);