CVE-2024-42109
Published: Jul 30, 2024
Modified: May 23, 2026
Description
In the Linux kernel, the following vulnerability has been resolved: netfilter: nf_tables: unconditionally flush pending work before notifier syzbot reports: KASAN: slab-uaf in nft_ctx_update include/net/netfilter/nf_tables.h:1831 KASAN: slab-uaf in nft_commit_release net/netfilter/nf_tables_api.c:9530 KASAN: slab-uaf int nf_tables_trans_destroy_work+0x152b/0x1750 net/netfilter/nf_tables_api.c:9597 Read of size 2 at addr ffff88802b0051c4 by task kworker/1:1/45 [..] Workqueue: events nf_tables_trans_destroy_work Call Trace: nft_ctx_update include/net/netfilter/nf_tables.h:1831 [inline] nft_commit_release net/netfilter/nf_tables_api.c:9530 [inline] nf_tables_trans_destroy_work+0x152b/0x1750 net/netfilter/nf_tables_api.c:9597 Problem is that the notifier does a conditional flush, but its possible that the table-to-be-removed is still referenced by transactions being processed by the worker, so we need to flush unconditionally. We could make the flush_work depend on whether we found a table to delete in nf-next to avoid the flush for most cases. AFAICS this problem is only exposed in nf-next, with commit e169285f8c56 ("netfilter: nf_tables: do not store nft_ctx in transaction objects"), with this commit applied there is an unconditional fetch of table->family which is whats triggering the above splat.
| Vendor | Product | Versions |
|---|---|---|
Linux | Linux | affected f22954f8c58fd5f5489f5980796914e306757e77 - < 3325628cb36b7f216c5716e7b5124d9dc81199e4affected 41841b585e53babdfb0fa6fdfa54f6d7c28c1206 - < 4c06c13317b9a08decedcd7aaf706691e336277caffected 2c9f0293280e258606e54ed2b96fa71498432eae - < 55a40406aac555defe9bdd0adec9508116ce7cb1affected 2c9f0293280e258606e54ed2b96fa71498432eae - < 09e650c3a3a7d804430260510534ccbf71c75b2eaffected 2c9f0293280e258606e54ed2b96fa71498432eae - < 9f6958ba2e902f9820c594869bd710ba74b7c4c0+4 more versions |
Linux | Linux | affected 6.5unaffected 0 - < 6.5unaffected 5.15.163 - <= 5.15.*unaffected 6.1.98 - <= 6.1.*unaffected 6.6.39 - <= 6.6.*+2 more versions |
References
Security Training
Train your team to recognize and prevent security threats with our comprehensive security awareness program.
Start TrainingVulnerability Scanning
Discover vulnerabilities in your applications and infrastructure before attackers do.
Scan Now