aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/fpga/altera-fpga2sdram.c
diff options
context:
space:
mode:
authorJann Horn <[email protected]>2024-11-18 16:33:13 +0000
committerJan Kara <[email protected]>2024-11-18 16:33:13 +0000
commit21d1b618b6b9da46c5116c640ac4b1cc8d40d63a (patch)
tree9359bcb968a59530fb9b17ee85d1e48c6b36b500 /drivers/fpga/altera-fpga2sdram.c
parentfsnotify: fix sending inotify event with unexpected filename (diff)
downloadkernel-21d1b618b6b9da46c5116c640ac4b1cc8d40d63a.tar.gz
kernel-21d1b618b6b9da46c5116c640ac4b1cc8d40d63a.zip
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. Cc: [email protected] Fixes: d2f277e26f52 ("fsnotify: rename fsnotify_{get,put}_sb_connectors()") Signed-off-by: Jann Horn <[email protected]> Signed-off-by: Jan Kara <[email protected]>
Diffstat (limited to 'drivers/fpga/altera-fpga2sdram.c')
0 files changed, 0 insertions, 0 deletions