CVE-2024-53143 Information

Description

In the Linux kernel the following vulnerability has been resolved:

fsnotify: Fix ordering of iput() and watched_objects decrement

Ensure the superblock is kept alive until we’re done with iput(). Holding a reference to an inode is not allowed unless we ensure the superblock stays alive which fsnotify does by keeping the watched_objects count elevated so iput() must happen before the watched_objects decrement. This can lead to a UAF of something like sb->s_fs_info in tmpfs but the UAF is hard to hit because race orderings that oops are more likely thanks to the CHECK_DATA_CORRUPTION() block in generic_shutdown_super().

Also ensure that fsnotify_put_sb_watched_objects() doesn’t call fsnotify_sb_watched_objects() on a superblock that may have already been freed which would cause a UAF read of sb->s_fsnotify_info.

Reference

https://git.kernel.org/stable/c/21d1b618b6b9da46c5116c640ac4b1cc8d40d63a https://git.kernel.org/stable/c/45a8f8232a495221ed058191629f5c628f21601a https://git.kernel.org/stable/c/83af1cfa10d9aafdabd06b3655e07727f373b434

Share on: