In the Linux kernel, the following vulnerability has been resolved:
io-wq: check for wq exit after adding new worker task_work
We check IO_WQ_BIT_EXIT before attempting to create a new worker, and
wq exit cancels pending work if we have any. But it’s possible to have
a race between the two, where creation checks exit finding it not set,
but we’re in the process of exiting. The exit side will cancel pending
creation task_work, but there’s a gap where we add task_work after we’ve
canceled existing creations at exit time.
Fix this by checking the EXIT bit post adding the creation task_work.
If it’s set, run the same cancelation that exit does.
[
{
"repo": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git",
"vendor": "Linux",
"product": "Linux",
"versions": [
{
"status": "affected",
"version": "1da177e4c3f4",
"lessThan": "4b4e5bbf9386",
"versionType": "git"
},
{
"status": "affected",
"version": "1da177e4c3f4",
"lessThan": "71a85387546e",
"versionType": "git"
}
],
"programFiles": [
"fs/io-wq.c"
],
"defaultStatus": "unaffected"
},
{
"repo": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git",
"vendor": "Linux",
"product": "Linux",
"versions": [
{
"status": "unaffected",
"version": "5.15.11",
"versionType": "custom",
"lessThanOrEqual": "5.15.*"
},
{
"status": "unaffected",
"version": "5.16",
"versionType": "original_commit_for_fix",
"lessThanOrEqual": "*"
}
],
"programFiles": [
"fs/io-wq.c"
],
"defaultStatus": "affected"
}
]