Description
In the Linux kernel, the following vulnerability has been resolved: ocfs2: split transactions in dio completion to avoid credit exhaustion During ocfs2 dio operations, JBD2 may report warnings via following call trace: ocfs2_dio_end_io_write ocfs2_mark_extent_written ocfs2_change_extent_flag ocfs2_split_extent ocfs2_try_to_merge_extent ocfs2_extend_rotate_transaction ocfs2_extend_trans jbd2__journal_restart start_this_handle output: JBD2: kworker/6:2 wants too many credits credits:5450 rsv_credits:0 max:5449 To prevent exceeding the credits limit, modify ocfs2_dio_end_io_write() to handle extents in a batch of transaction. Additionally, relocate ocfs2_del_inode_from_orphan(). The orphan inode should only be removed from the orphan list after the extent tree update is complete. This ensures that if a crash occurs in the middle of extent tree updates, we won't leave stale blocks beyond EOF. This patch also changes the logic for updating the inode size and removing orphan, making it similar to ext4_dio_write_end_io(). Both operations are performed only when everything looks good. Finally, thanks to Jans and Joseph for providing the bug fix prototype and suggestions.
Product status
c15471f79506830f80eca0e7fe09b8213953ab5f (git) before 97c03c0e9f73a5049794b3c69ee60fb5e8b0ebd8
c15471f79506830f80eca0e7fe09b8213953ab5f (git) before 1e99bb19994246514d63e656492904176f9d5edd
c15471f79506830f80eca0e7fe09b8213953ab5f (git) before 91e05ac2336d00d5b99fc774be4bd50039084796
c15471f79506830f80eca0e7fe09b8213953ab5f (git) before 886f97fa59d0bbfa9859fb1a66dd9e014b522d89
c15471f79506830f80eca0e7fe09b8213953ab5f (git) before ea5bb1d20da756e4f41a48dad42b2e7d6e73f71e
c15471f79506830f80eca0e7fe09b8213953ab5f (git) before 3c636a3edca9c3f180b3079f94fe7e115730d9c6
c15471f79506830f80eca0e7fe09b8213953ab5f (git) before 069c3fb310e9336cf48cfdf8748a32c29fd0193d
c15471f79506830f80eca0e7fe09b8213953ab5f (git) before d647c5b2fbf81560818dacade360abc8c00a9665
4.6
Any version before 4.6
5.10.258 (semver)
5.15.209 (semver)
6.1.175 (semver)
6.6.140 (semver)
6.12.86 (semver)
6.18.27 (semver)
7.0.4 (semver)
7.1-rc1 (original_commit_for_fix)
References
git.kernel.org/...c/97c03c0e9f73a5049794b3c69ee60fb5e8b0ebd8
git.kernel.org/...c/1e99bb19994246514d63e656492904176f9d5edd
git.kernel.org/...c/91e05ac2336d00d5b99fc774be4bd50039084796
git.kernel.org/...c/886f97fa59d0bbfa9859fb1a66dd9e014b522d89
git.kernel.org/...c/ea5bb1d20da756e4f41a48dad42b2e7d6e73f71e
git.kernel.org/...c/3c636a3edca9c3f180b3079f94fe7e115730d9c6
git.kernel.org/...c/069c3fb310e9336cf48cfdf8748a32c29fd0193d
git.kernel.org/...c/d647c5b2fbf81560818dacade360abc8c00a9665