sctp: add a refcnt in sctp_stream_priorities to avoid a nested loop
Description
In the Linux kernel, the following vulnerability has been resolved:
sctp: add a refcnt in sctp_stream_priorities to avoid a nested loop
With this refcnt added in sctp_stream_priorities, we don't need to traverse all streams to check if the prio is used by other streams when freeing one stream's prio in sctp_sched_prio_free_sid(). This can avoid a nested loop (up to 65535 * 65535), which may cause a stuck as Ying reported:
watchdog: BUG: soft lockup - CPU#23 stuck for 26s! [ksoftirqd/23:136] Call Trace:
sctp_sched_prio_free_sid+0xab/0x100 [sctp] sctp_stream_free_ext+0x64/0xa0 [sctp] sctp_stream_free+0x31/0x50 [sctp] sctp_association_free+0xa5/0x200 [sctp]
Note that it doesn't need to use refcount_t type for this counter, as its accessing is always protected under the sock lock.
v1->v2: - add a check in sctp_sched_prio_set to avoid the possible prio_head refcnt overflow.
Affected products
2- Linux/Linuxv5Range: 6.1
Patches
0No patches discovered yet.
Vulnerability mechanics
AI mechanics synthesis has not run for this CVE yet.
References
6- git.kernel.org/stable/c/03c3a5584a0a29821e59b7834635ce823050caaamitre
- git.kernel.org/stable/c/68ba44639537de6f91fe32783766322d41848127mitre
- git.kernel.org/stable/c/6d529928ea212127851a2df8c40d822237ca946bmitre
- git.kernel.org/stable/c/8ee401f89cdb10f39098c0656d695b2bc4052100mitre
- git.kernel.org/stable/c/bf5540cbd20e2dae2c81ab9b31deef41ef147d0amitre
- git.kernel.org/stable/c/cec326443f01283ef68ea00c06ea073b1835a562mitre
News mentions
0No linked articles in our index yet.