CVE-2024-56655
Severity CVSS v4.0:
Pending analysis
Type:
Unavailable / Other
Publication date:
27/12/2024
Last modified:
04/06/2025
Description
In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
netfilter: nf_tables: do not defer rule destruction via call_rcu<br />
<br />
nf_tables_chain_destroy can sleep, it can&#39;t be used from call_rcu<br />
callbacks.<br />
<br />
Moreover, nf_tables_rule_release() is only safe for error unwinding,<br />
while transaction mutex is held and the to-be-desroyed rule was not<br />
exposed to either dataplane or dumps, as it deactives+frees without<br />
the required synchronize_rcu() in-between.<br />
<br />
nft_rule_expr_deactivate() callbacks will change ->use counters<br />
of other chains/sets, see e.g. nft_lookup .deactivate callback, these<br />
must be serialized via transaction mutex.<br />
<br />
Also add a few lockdep asserts to make this more explicit.<br />
<br />
Calling synchronize_rcu() isn&#39;t ideal, but fixing this without is hard<br />
and way more intrusive. As-is, we can get:<br />
<br />
WARNING: .. net/netfilter/nf_tables_api.c:5515 nft_set_destroy+0x..<br />
Workqueue: events nf_tables_trans_destroy_work<br />
RIP: 0010:nft_set_destroy+0x3fe/0x5c0<br />
Call Trace:<br />
<br />
nf_tables_trans_destroy_work+0x6b7/0xad0<br />
process_one_work+0x64a/0xce0<br />
worker_thread+0x613/0x10d0<br />
<br />
In case the synchronize_rcu becomes an issue, we can explore alternatives.<br />
<br />
One way would be to allocate nft_trans_rule objects + one nft_trans_chain<br />
object, deactivate the rules + the chain and then defer the freeing to the<br />
nft destroy workqueue. We&#39;d still need to keep the synchronize_rcu path as<br />
a fallback to handle -ENOMEM corner cases though.
Impact
Base Score 3.x
5.50
Severity 3.x
MEDIUM
Vulnerable products and versions
CPE | From | Up to |
---|---|---|
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.6.61 (including) | 6.6.67 (excluding) |
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.11.8 (including) | 6.12.6 (excluding) |
cpe:2.3:o:linux:linux_kernel:6.13:rc1:*:*:*:*:*:* | ||
cpe:2.3:o:linux:linux_kernel:6.13:rc2:*:*:*:*:*:* |
To consult the complete list of CPE names with products and versions, see this page
References to Advisories, Solutions, and Tools
- https://git.kernel.org/stable/c/27f0574253f6c24c8ee4e3f0a685b75ed3a256ed
- https://git.kernel.org/stable/c/2991dc357a28b61c13ed1f7b59e9251e2b4562fb
- https://git.kernel.org/stable/c/5146c27b2780aac59876a887a5f4e793b8949862
- https://git.kernel.org/stable/c/7cf0bd232b565d9852cb25fd094f77254773e048
- https://git.kernel.org/stable/c/b04df3da1b5c6f6dc7cdccc37941740c078c4043
- https://git.kernel.org/stable/c/b0f013bebf94fe7ae75e5a53be2f2bd1cc1841e3
- https://git.kernel.org/stable/c/b8d8f53e1858178882b881b8c09f94ef0e83bf76