CVE-2024-35960
mlx5 Linux Kernel Null Pointer Dereference Vulnerability
Description
In the Linux kernel, the following vulnerability has been resolved: net/mlx5: Properly link new fs rules into the tree Previously, add_rule_fg would only add newly created rules from the handle into the tree when they had a refcount of 1. On the other hand, create_flow_handle tries hard to find and reference already existing identical rules instead of creating new ones. These two behaviors can result in a situation where create_flow_handle 1) creates a new rule and references it, then 2) in a subsequent step during the same handle creation references it again, resulting in a rule with a refcount of 2 that is not linked into the tree, will have a NULL parent and root and will result in a crash when the flow group is deleted because del_sw_hw_rule, invoked on rule deletion, assumes node->parent is != NULL. This happened in the wild, due to another bug related to incorrect handling of duplicate pkt_reformat ids, which lead to the code in create_flow_handle incorrectly referencing a just-added rule in the same flow handle, resulting in the problem described above. Full details are at [1]. This patch changes add_rule_fg to add new rules without parents into the tree, properly initializing them and avoiding the crash. This makes it more consistent with how rules are added to an FTE in create_flow_handle.
INFO
Published Date :
May 20, 2024, 10:15 a.m.
Last Modified :
April 4, 2025, 2:22 p.m.
Source :
416baaa9-dc9f-4396-8d5f-8c081fb06d67
Remotely Exploitable :
Yes !
Impact Score :
5.2
Exploitability Score :
3.9
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-35960
.
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-35960
vulnerability anywhere in the article.
The following table lists the changes that have been made to the
CVE-2024-35960
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. 04, 2025
Action Type Old Value New Value Added CPE Configuration OR *cpe:2.3:o:linux:linux_kernel:6.9:rc3:*:*:*:*:*:* *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) 5.5 up to (excluding) 5.10.216 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 4.20 up to (excluding) 5.4.275 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 5.11 up to (excluding) 5.15.156 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 4.10 up to (excluding) 4.19.313 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 5.16 up to (excluding) 6.1.87 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 6.2 up to (excluding) 6.6.28 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 6.7 up to (excluding) 6.8.7 Added CPE Configuration OR *cpe:2.3:o:debian:debian_linux:10.0:*:*:*:*:*:*:* Added Reference Type CVE: https://git.kernel.org/stable/c/1263b0b26077b1183c3c45a0a2479573a351d423 Types: Patch Added Reference Type kernel.org: https://git.kernel.org/stable/c/1263b0b26077b1183c3c45a0a2479573a351d423 Types: Patch Added Reference Type CVE: https://git.kernel.org/stable/c/2e8dc5cffc844dacfa79f056dea88002312f253f Types: Patch Added Reference Type kernel.org: https://git.kernel.org/stable/c/2e8dc5cffc844dacfa79f056dea88002312f253f Types: Patch Added Reference Type CVE: https://git.kernel.org/stable/c/3d90ca9145f6b97b38d0c2b6b30f6ca6af9c1801 Types: Patch Added Reference Type kernel.org: https://git.kernel.org/stable/c/3d90ca9145f6b97b38d0c2b6b30f6ca6af9c1801 Types: Patch Added Reference Type CVE: https://git.kernel.org/stable/c/5cf5337ef701830f173b4eec00a4f984adeb57a0 Types: Patch Added Reference Type kernel.org: https://git.kernel.org/stable/c/5cf5337ef701830f173b4eec00a4f984adeb57a0 Types: Patch Added Reference Type CVE: https://git.kernel.org/stable/c/7aaee12b804c5e0374e7b132b6ec2158ff33dd64 Types: Patch Added Reference Type kernel.org: https://git.kernel.org/stable/c/7aaee12b804c5e0374e7b132b6ec2158ff33dd64 Types: Patch Added Reference Type CVE: https://git.kernel.org/stable/c/7c6782ad4911cbee874e85630226ed389ff2e453 Types: Patch Added Reference Type kernel.org: https://git.kernel.org/stable/c/7c6782ad4911cbee874e85630226ed389ff2e453 Types: Patch Added Reference Type CVE: https://git.kernel.org/stable/c/adf67a03af39095f05d82050f15813d6f700159d Types: Patch Added Reference Type kernel.org: https://git.kernel.org/stable/c/adf67a03af39095f05d82050f15813d6f700159d Types: Patch Added Reference Type CVE: https://git.kernel.org/stable/c/de0139719cdda82806a47580ca0df06fc85e0bd2 Types: Patch Added Reference Type kernel.org: https://git.kernel.org/stable/c/de0139719cdda82806a47580ca0df06fc85e0bd2 Types: Patch Added Reference Type CVE: https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html Types: Mailing List, Third Party Advisory Added Reference Type CVE: https://lists.debian.org/debian-lts-announce/2024/06/msg00020.html Types: Mailing List, Third Party Advisory -
CVE Modified by af854a3a-2127-422b-91ae-364da2661108
Nov. 21, 2024
Action Type Old Value New Value Added Reference https://git.kernel.org/stable/c/1263b0b26077b1183c3c45a0a2479573a351d423 Added Reference https://git.kernel.org/stable/c/2e8dc5cffc844dacfa79f056dea88002312f253f Added Reference https://git.kernel.org/stable/c/3d90ca9145f6b97b38d0c2b6b30f6ca6af9c1801 Added Reference https://git.kernel.org/stable/c/5cf5337ef701830f173b4eec00a4f984adeb57a0 Added Reference https://git.kernel.org/stable/c/7aaee12b804c5e0374e7b132b6ec2158ff33dd64 Added Reference https://git.kernel.org/stable/c/7c6782ad4911cbee874e85630226ed389ff2e453 Added Reference https://git.kernel.org/stable/c/adf67a03af39095f05d82050f15813d6f700159d Added Reference https://git.kernel.org/stable/c/de0139719cdda82806a47580ca0df06fc85e0bd2 Added Reference https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html Added Reference https://lists.debian.org/debian-lts-announce/2024/06/msg00020.html -
CVE Modified by 416baaa9-dc9f-4396-8d5f-8c081fb06d67
Nov. 05, 2024
Action Type Old Value New Value Removed Reference kernel.org https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html Removed Reference kernel.org https://lists.debian.org/debian-lts-announce/2024/06/msg00020.html -
CVE Modified by 134c704f-9b21-4f2e-91b3-4a467353bcc0
Jul. 03, 2024
Action Type Old Value New Value Added CWE CISA-ADP CWE-476 Added CVSS V3.1 CISA-ADP AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:H/A:H -
CVE Modified by 416baaa9-dc9f-4396-8d5f-8c081fb06d67
Jun. 27, 2024
Action Type Old Value New Value Added Reference kernel.org https://lists.debian.org/debian-lts-announce/2024/06/msg00020.html [No types assigned] -
CVE Modified by 416baaa9-dc9f-4396-8d5f-8c081fb06d67
Jun. 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-8c081fb06d67
May. 29, 2024
Action Type Old Value New Value -
CVE Received by 416baaa9-dc9f-4396-8d5f-8c081fb06d67
May. 20, 2024
Action Type Old Value New Value Added Description In the Linux kernel, the following vulnerability has been resolved: net/mlx5: Properly link new fs rules into the tree Previously, add_rule_fg would only add newly created rules from the handle into the tree when they had a refcount of 1. On the other hand, create_flow_handle tries hard to find and reference already existing identical rules instead of creating new ones. These two behaviors can result in a situation where create_flow_handle 1) creates a new rule and references it, then 2) in a subsequent step during the same handle creation references it again, resulting in a rule with a refcount of 2 that is not linked into the tree, will have a NULL parent and root and will result in a crash when the flow group is deleted because del_sw_hw_rule, invoked on rule deletion, assumes node->parent is != NULL. This happened in the wild, due to another bug related to incorrect handling of duplicate pkt_reformat ids, which lead to the code in create_flow_handle incorrectly referencing a just-added rule in the same flow handle, resulting in the problem described above. Full details are at [1]. This patch changes add_rule_fg to add new rules without parents into the tree, properly initializing them and avoiding the crash. This makes it more consistent with how rules are added to an FTE in create_flow_handle. Added Reference kernel.org https://git.kernel.org/stable/c/de0139719cdda82806a47580ca0df06fc85e0bd2 [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/1263b0b26077b1183c3c45a0a2479573a351d423 [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/3d90ca9145f6b97b38d0c2b6b30f6ca6af9c1801 [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/7aaee12b804c5e0374e7b132b6ec2158ff33dd64 [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/2e8dc5cffc844dacfa79f056dea88002312f253f [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/5cf5337ef701830f173b4eec00a4f984adeb57a0 [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/adf67a03af39095f05d82050f15813d6f700159d [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/7c6782ad4911cbee874e85630226ed389ff2e453 [No types assigned]
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-35960
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-35960
weaknesses.