]> git.baikalelectronics.ru Git - kernel.git/commit
jbd2: fix use-after-free of transaction_t race
authorRitesh Harjani <riteshh@linux.ibm.com>
Thu, 10 Feb 2022 15:37:11 +0000 (21:07 +0530)
committerTheodore Ts'o <tytso@mit.edu>
Sat, 26 Feb 2022 02:28:10 +0000 (21:28 -0500)
commite4813297f01b0cf3f7f454a8bf4bec2bd1d983cb
treed987da63f7476ca23d89f8dd9f4656d0a227e3d3
parentf6d612c5a939843639c03fda86cec51d31854843
jbd2: fix use-after-free of transaction_t race

jbd2_journal_wait_updates() is called with j_state_lock held. But if
there is a commit in progress, then this transaction might get committed
and freed via jbd2_journal_commit_transaction() ->
jbd2_journal_free_transaction(), when we release j_state_lock.
So check for journal->j_running_transaction everytime we release and
acquire j_state_lock to avoid use-after-free issue.

Link: https://lore.kernel.org/r/948c2fed518ae739db6a8f7f83f1d58b504f87d0.1644497105.git.ritesh.list@gmail.com
Fixes: d482720a32d0cc3b ("jbd2: refactor wait logic for transaction updates into a common function")
Cc: stable@kernel.org
Reported-and-tested-by: syzbot+afa2ca5171d93e44b348@syzkaller.appspotmail.com
Reviewed-by: Jan Kara <jack@suse.cz>
Signed-off-by: Ritesh Harjani <riteshh@linux.ibm.com>
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
fs/jbd2/transaction.c