CVE-2024-56655
MediumIn the Linux kernel, the following vulnerability has been resolved: netfilter: nf_tables: do not defer rule destruction via call_rcu nf_tables_chain_destroy can sleep, it can't be used from call_rcu callbacks. Moreover, nf_tables_rule_release() is only safe for error unwinding, while transaction mutex is held and the to-be-desroyed rule was not exposed to either dataplane or dumps, as it deactives+frees without the required synchronize_rcu() in-between. nft_rule_expr_deactivate() callbacks will change ->use counters of other chains/sets, see e.g. nft_lookup .deactivate callback, these must be serialized via transaction mutex. Also add a few lockdep asserts to make this more explicit. Calling synchronize_rcu() isn't ideal, but fixing this without is hard and way more intrusive. As-is, we can get: WARNING: .. net/netfilter/nf_tables_api.c:5515 nft_set_destroy+0x.. Workqueue: events nf_tables_trans_destroy_work RIP: 0010:nft_set_destroy+0x3fe/0x5c0 Call Trace: <TASK> nf_tables_trans_destroy_work+0x6b7/0xad0 process_one_work+0x64a/0xce0 worker_thread+0x613/0x10d0 In case the synchronize_rcu becomes an issue, we can explore alternatives. One way would be to allocate nft_trans_rule objects + one nft_trans_chain object, deactivate the rules + the chain and then defer the freeing to the nft destroy workqueue. We'd still need to keep the synchronize_rcu path as a fallback to handle -ENOMEM corner cases though.
CVSS 3.1 score
5.5
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H
Affected versions
Linux kernel versions
6.6.61,
6.11.8,
6.12
and later are affected. Fixed in
6.6.67,
6.12.6,
6.13
and their respective stable series.
References
The following references provide additional information about CVE-2024-56655 including vendor advisories, patch commits, exploit details, and third-party analysis. Links are sourced from the NIST NVD database.
-
PatchKernel patch commithttps://git.kernel.org/stable/c/27f0574253f6c24c8ee4e3f0a685b75ed3a256ed
-
PatchKernel patch commithttps://git.kernel.org/stable/c/2991dc357a28b61c13ed1f7b59e9251e2b4562fb
-
PatchKernel patch commithttps://git.kernel.org/stable/c/5146c27b2780aac59876a887a5f4e793b8949862
Frequently asked questions
-
What is CVE-2024-56655?
CVE-2024-56655 is a Medium severity Linux kernel vulnerability with a CVSS score of 5.5 out of 10 . It affects Linux kernel versions from 6.6.61 onward and has been patched in 6.6.67, 6.12.6 and 6.13. CVE-2024-56655 has not been confirmed as actively exploited and is not listed in the CISA KEV catalog.
-
What is the CVSS score for CVE-2024-56655?
CVE-2024-56655 has a CVSS score of 5.5 out of 10, rated Medium severity (CVSS 3.1). The vector string is
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H. -
Is there a patch available for CVE-2024-56655?
Yes — CVE-2024-56655 has been patched. Fixed versions include 6.6.67, 6.12.6 and 6.13. If you are running Linux kernel 6.6.61 or later up to the fix versions, apply the relevant patch for your kernel branch.
-
Is CVE-2024-56655 actively exploited?
No — CVE-2024-56655 has not been confirmed as actively exploited. It is not listed in the CISA Known Exploited Vulnerabilities (KEV) catalog.