CVE-2024-35853
mlxsw: spectrum_acl_tcam: Fix memory leak during rehash
Description
In the Linux kernel, the following vulnerability has been resolved: mlxsw: spectrum_acl_tcam: Fix memory leak during rehash The rehash delayed work migrates filters from one region to another. This is done by iterating over all chunks (all the filters with the same priority) in the region and in each chunk iterating over all the filters. If the migration fails, the code tries to migrate the filters back to the old region. However, the rollback itself can also fail in which case another migration will be erroneously performed. Besides the fact that this ping pong is not a very good idea, it also creates a problem. Each virtual chunk references two chunks: The currently used one ('vchunk->chunk') and a backup ('vchunk->chunk2'). During migration the first holds the chunk we want to migrate filters to and the second holds the chunk we are migrating filters from. The code currently assumes - but does not verify - that the backup chunk does not exist (NULL) if the currently used chunk does not reference the target region. This assumption breaks when we are trying to rollback a rollback, resulting in the backup chunk being overwritten and leaked [1]. Fix by not rolling back a failed rollback and add a warning to avoid future cases. [1] WARNING: CPU: 5 PID: 1063 at lib/parman.c:291 parman_destroy+0x17/0x20 Modules linked in: CPU: 5 PID: 1063 Comm: kworker/5:11 Tainted: G W 6.9.0-rc2-custom-00784-gc6a05c468a0b #14 Hardware name: Mellanox Technologies Ltd. MSN3700/VMOD0005, BIOS 5.11 01/06/2019 Workqueue: mlxsw_core mlxsw_sp_acl_tcam_vregion_rehash_work RIP: 0010:parman_destroy+0x17/0x20 [...] Call Trace: <TASK> mlxsw_sp_acl_atcam_region_fini+0x19/0x60 mlxsw_sp_acl_tcam_region_destroy+0x49/0xf0 mlxsw_sp_acl_tcam_vregion_rehash_work+0x1f1/0x470 process_one_work+0x151/0x370 worker_thread+0x2cb/0x3e0 kthread+0xd0/0x100 ret_from_fork+0x34/0x50 ret_from_fork_asm+0x1a/0x30 </TASK>
INFO
Published Date :
May 17, 2024, 3:15 p.m.
Last Modified :
April 7, 2025, 7:03 p.m.
Remotely Exploit :
Yes !
Source :
416baaa9-dc9f-4396-8d5f-8c081fb06d67
CVSS Scores
| Score | Version | Severity | Vector | Exploitability Score | Impact Score | Source | 
|---|---|---|---|---|---|---|
| CVSS 3.1 | MEDIUM | 134c704f-9b21-4f2e-91b3-4a467353bcc0 | 
Solution
- Update the affected Linux kernel packages.
- Reboot the system after the update.
References to Advisories, Solutions, and Tools
                                            Here, you will find a curated list of external links that provide in-depth
                                            information, practical solutions, and valuable tools related to
                                            CVE-2024-35853.
                                        
CWE - Common Weakness Enumeration
            While CVE identifies
            specific instances of vulnerabilities, CWE categorizes the common flaws or
            weaknesses that can lead to vulnerabilities. CVE-2024-35853 is
            associated with the following CWEs:
        
Common Attack Pattern Enumeration and Classification (CAPEC)
Common Attack Pattern Enumeration and Classification
            (CAPEC)
            stores attack patterns, which are descriptions of the common attributes and
            approaches employed by adversaries to exploit the CVE-2024-35853
            weaknesses.
We scan GitHub repositories to detect new proof-of-concept exploits. Following list is a collection of public exploits and proof-of-concepts, which have been published on GitHub (sorted by the most recently updated).
Results are limited to the first 15 repositories due to potential performance issues.
			The following list is the news that have been mention
			CVE-2024-35853 vulnerability anywhere in the article.
		
                The following table lists the changes that have been made to the
                CVE-2024-35853 vulnerability over time.
            
Vulnerability history details can be useful for understanding the evolution of a vulnerability, and for identifying the most recent changes that may impact the vulnerability's severity, exploitability, or other characteristics.
- 
                            Initial Analysis by [email protected]Apr. 07, 2025 Action Type Old Value New Value Added CWE CWE-401 Added CPE Configuration OR *cpe:2.3:o:linux:linux_kernel:6.9:rc3:*:*:*:*:*:* *cpe:2.3:o:linux:linux_kernel:6.9:rc4:*:*:*:*:*:* *cpe:2.3:o:linux:linux_kernel:6.9:rc1:*:*:*:*:*:* *cpe:2.3:o:linux:linux_kernel:6.9:rc2:*:*:*:*:*:* *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 6.2 up to (excluding) 6.6.30 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 5.5 up to (excluding) 5.10.216 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 5.1 up to (excluding) 5.4.275 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 5.11 up to (excluding) 5.15.158 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 5.16 up to (excluding) 6.1.90 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 6.7 up to (excluding) 6.8.9 *cpe:2.3:o:linux:linux_kernel:6.9:rc5:*:*:*:*:*:* Added CPE Configuration OR *cpe:2.3:o:debian:debian_linux:10.0:*:*:*:*:*:*:* Added Reference Type CVE: https://git.kernel.org/stable/c/0ae8ff7b6d42e33943af462910bdcfa2ec0cb8cf Types: Patch Added Reference Type kernel.org: https://git.kernel.org/stable/c/0ae8ff7b6d42e33943af462910bdcfa2ec0cb8cf Types: Patch Added Reference Type CVE: https://git.kernel.org/stable/c/413a01886c3958d4b8aac23a3bff3d430b92093e Types: Patch Added Reference Type kernel.org: https://git.kernel.org/stable/c/413a01886c3958d4b8aac23a3bff3d430b92093e Types: Patch Added Reference Type CVE: https://git.kernel.org/stable/c/617e98ba4c50f4547c9eb0946b1cfc26937d70d1 Types: Patch Added Reference Type kernel.org: https://git.kernel.org/stable/c/617e98ba4c50f4547c9eb0946b1cfc26937d70d1 Types: Patch Added Reference Type CVE: https://git.kernel.org/stable/c/8ca3f7a7b61393804c46f170743c3b839df13977 Types: Patch Added Reference Type kernel.org: https://git.kernel.org/stable/c/8ca3f7a7b61393804c46f170743c3b839df13977 Types: Patch Added Reference Type CVE: https://git.kernel.org/stable/c/b3fd51f684a0711504f82de510da109ae639722d Types: Patch Added Reference Type kernel.org: https://git.kernel.org/stable/c/b3fd51f684a0711504f82de510da109ae639722d Types: Patch Added Reference Type CVE: https://git.kernel.org/stable/c/b822644fd90992ee362c5e0c8d2556efc8856c76 Types: Patch Added Reference Type kernel.org: https://git.kernel.org/stable/c/b822644fd90992ee362c5e0c8d2556efc8856c76 Types: Patch Added Reference Type CVE: https://git.kernel.org/stable/c/c6f3fa7f5a748bf6e5c4eb742686d6952f854e76 Types: Patch Added Reference Type kernel.org: https://git.kernel.org/stable/c/c6f3fa7f5a748bf6e5c4eb742686d6952f854e76 Types: Patch Added Reference Type CVE: https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html Types: Mailing List, Third Party Advisory 
- 
                            CVE Modified by af854a3a-2127-422b-91ae-364da2661108Nov. 21, 2024 Action Type Old Value New Value Added Reference https://git.kernel.org/stable/c/0ae8ff7b6d42e33943af462910bdcfa2ec0cb8cf Added Reference https://git.kernel.org/stable/c/413a01886c3958d4b8aac23a3bff3d430b92093e Added Reference https://git.kernel.org/stable/c/617e98ba4c50f4547c9eb0946b1cfc26937d70d1 Added Reference https://git.kernel.org/stable/c/8ca3f7a7b61393804c46f170743c3b839df13977 Added Reference https://git.kernel.org/stable/c/b3fd51f684a0711504f82de510da109ae639722d Added Reference https://git.kernel.org/stable/c/b822644fd90992ee362c5e0c8d2556efc8856c76 Added Reference https://git.kernel.org/stable/c/c6f3fa7f5a748bf6e5c4eb742686d6952f854e76 Added Reference https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html 
- 
                            CVE Modified by 416baaa9-dc9f-4396-8d5f-8c081fb06d67Nov. 05, 2024 Action Type Old Value New Value Removed Reference kernel.org https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html 
- 
                            CVE Modified by 134c704f-9b21-4f2e-91b3-4a467353bcc0Aug. 01, 2024 Action Type Old Value New Value Removed CWE CISA-ADP CWE-416 
- 
                            CVE Modified by 134c704f-9b21-4f2e-91b3-4a467353bcc0Jul. 03, 2024 Action Type Old Value New Value Added CWE CISA-ADP CWE-416 Added CVSS V3.1 CISA-ADP AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:L/A:H 
- 
                            CVE Modified by 416baaa9-dc9f-4396-8d5f-8c081fb06d67Jun. 25, 2024 Action Type Old Value New Value Added Reference kernel.org https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html [No types assigned] 
- 
                            CVE Modified by 416baaa9-dc9f-4396-8d5f-8c081fb06d67May. 29, 2024 Action Type Old Value New Value 
- 
                            CVE Received by 416baaa9-dc9f-4396-8d5f-8c081fb06d67May. 17, 2024 Action Type Old Value New Value Added Description In the Linux kernel, the following vulnerability has been resolved: mlxsw: spectrum_acl_tcam: Fix memory leak during rehash The rehash delayed work migrates filters from one region to another. This is done by iterating over all chunks (all the filters with the same priority) in the region and in each chunk iterating over all the filters. If the migration fails, the code tries to migrate the filters back to the old region. However, the rollback itself can also fail in which case another migration will be erroneously performed. Besides the fact that this ping pong is not a very good idea, it also creates a problem. Each virtual chunk references two chunks: The currently used one ('vchunk->chunk') and a backup ('vchunk->chunk2'). During migration the first holds the chunk we want to migrate filters to and the second holds the chunk we are migrating filters from. The code currently assumes - but does not verify - that the backup chunk does not exist (NULL) if the currently used chunk does not reference the target region. This assumption breaks when we are trying to rollback a rollback, resulting in the backup chunk being overwritten and leaked [1]. Fix by not rolling back a failed rollback and add a warning to avoid future cases. [1] WARNING: CPU: 5 PID: 1063 at lib/parman.c:291 parman_destroy+0x17/0x20 Modules linked in: CPU: 5 PID: 1063 Comm: kworker/5:11 Tainted: G W 6.9.0-rc2-custom-00784-gc6a05c468a0b #14 Hardware name: Mellanox Technologies Ltd. MSN3700/VMOD0005, BIOS 5.11 01/06/2019 Workqueue: mlxsw_core mlxsw_sp_acl_tcam_vregion_rehash_work RIP: 0010:parman_destroy+0x17/0x20 [...] Call Trace: <TASK> mlxsw_sp_acl_atcam_region_fini+0x19/0x60 mlxsw_sp_acl_tcam_region_destroy+0x49/0xf0 mlxsw_sp_acl_tcam_vregion_rehash_work+0x1f1/0x470 process_one_work+0x151/0x370 worker_thread+0x2cb/0x3e0 kthread+0xd0/0x100 ret_from_fork+0x34/0x50 ret_from_fork_asm+0x1a/0x30 </TASK> Added Reference kernel.org https://git.kernel.org/stable/c/c6f3fa7f5a748bf6e5c4eb742686d6952f854e76 [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/617e98ba4c50f4547c9eb0946b1cfc26937d70d1 [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/413a01886c3958d4b8aac23a3bff3d430b92093e [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/b822644fd90992ee362c5e0c8d2556efc8856c76 [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/0ae8ff7b6d42e33943af462910bdcfa2ec0cb8cf [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/b3fd51f684a0711504f82de510da109ae639722d [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/8ca3f7a7b61393804c46f170743c3b839df13977 [No types assigned] 
 
                         
                         
                         
                                             
                                            