Home

Description

In the Linux kernel, the following vulnerability has been resolved: netfilter: ctnetlink: fix refcount leak on table dump There is a reference count leak in ctnetlink_dump_table(): if (res < 0) { nf_conntrack_get(&ct->ct_general); // HERE cb->args[1] = (unsigned long)ct; ... While its very unlikely, its possible that ct == last. If this happens, then the refcount of ct was already incremented. This 2nd increment is never undone. This prevents the conntrack object from being released, which in turn keeps prevents cnet->count from dropping back to 0. This will then block the netns dismantle (or conntrack rmmod) as nf_conntrack_cleanup_net_list() will wait forever. This can be reproduced by running conntrack_resize.sh selftest in a loop. It takes ~20 minutes for me on a preemptible kernel on average before I see a runaway kworker spinning in nf_conntrack_cleanup_net_list. One fix would to change this to: if (res < 0) { if (ct != last) nf_conntrack_get(&ct->ct_general); But this reference counting isn't needed in the first place. We can just store a cookie value instead. A followup patch will do the same for ctnetlink_exp_dump_table, it looks to me as if this has the same problem and like ctnetlink_dump_table, we only need a 'skip hint', not the actual object so we can apply the same cookie strategy there as well.

PUBLISHED Reserved 2025-04-16 | Published 2025-09-04 | Updated 2025-09-29 | Assigner Linux

Product status

Default status
unaffected

d205dc40798d97d63ad348bfaf7394f445d152d4 (git) before 586892e341fbf698e7cbaca293e1353957db725a
affected

d205dc40798d97d63ad348bfaf7394f445d152d4 (git) before 962518c6ca9f9a13df099cafa429f72f68ad61f0
affected

d205dc40798d97d63ad348bfaf7394f445d152d4 (git) before 19b909a4b1452fb97e477d2f08b97f8d04095619
affected

d205dc40798d97d63ad348bfaf7394f445d152d4 (git) before 41462f4cfc583513833f87f9ee55d12da651a7e3
affected

d205dc40798d97d63ad348bfaf7394f445d152d4 (git) before 30cf811058552b8cd0e98dff677ef3f89d6d34ce
affected

d205dc40798d97d63ad348bfaf7394f445d152d4 (git) before a2cb4df7872de069f809de2f076ec8e54d649fe3
affected

d205dc40798d97d63ad348bfaf7394f445d152d4 (git) before e14f72aa66c029db106921d621edcedef68e065b
affected

d205dc40798d97d63ad348bfaf7394f445d152d4 (git) before a62d6aa3f31f216b637a4c71b7a8bfc7c57f049b
affected

d205dc40798d97d63ad348bfaf7394f445d152d4 (git) before de788b2e6227462b6dcd0e07474e72c089008f74
affected

Default status
affected

2.6.18
affected

Any version before 2.6.18
unaffected

5.4.297 (semver)
unaffected

5.10.241 (semver)
unaffected

5.15.190 (semver)
unaffected

6.1.149 (semver)
unaffected

6.6.103 (semver)
unaffected

6.12.43 (semver)
unaffected

6.15.11 (semver)
unaffected

6.16.2 (semver)
unaffected

6.17 (original_commit_for_fix)
unaffected

References

git.kernel.org/...c/586892e341fbf698e7cbaca293e1353957db725a

git.kernel.org/...c/962518c6ca9f9a13df099cafa429f72f68ad61f0

git.kernel.org/...c/19b909a4b1452fb97e477d2f08b97f8d04095619

git.kernel.org/...c/41462f4cfc583513833f87f9ee55d12da651a7e3

git.kernel.org/...c/30cf811058552b8cd0e98dff677ef3f89d6d34ce

git.kernel.org/...c/a2cb4df7872de069f809de2f076ec8e54d649fe3

git.kernel.org/...c/e14f72aa66c029db106921d621edcedef68e065b

git.kernel.org/...c/a62d6aa3f31f216b637a4c71b7a8bfc7c57f049b

git.kernel.org/...c/de788b2e6227462b6dcd0e07474e72c089008f74

cve.org (CVE-2025-38721)

nvd.nist.gov (CVE-2025-38721)

Download JSON