5.5 CVE-2024-38553

Patch
 

In the Linux kernel, the following vulnerability has been resolved: net: fec: remove .ndo_poll_controller to avoid deadlocks There is a deadlock issue found in sungem driver, please refer to the commit ac0a230f719b ("eth: sungem: remove .ndo_poll_controller to avoid deadlocks"). The root cause of the issue is that netpoll is in atomic context and disable_irq() is called by .ndo_poll_controller interface of sungem driver, however, disable_irq() might sleep. After analyzing the implementation of fec_poll_controller(), the fec driver should have the same issue. Due to the fec driver uses NAPI for TX completions, the .ndo_poll_controller is unnecessary to be implemented in the fec driver, so fec_poll_controller() can be safely removed.
https://nvd.nist.gov/vuln/detail/CVE-2024-38553

Categories

CWE-667 : Improper Locking
The product does not properly acquire or release a lock on a resource, leading to unexpected resource state changes and behaviors. Automated static analysis, commonly referred to as Static Application Security Testing (SAST), can find some instances of this weakness by analyzing source code (or binary/compiled code) without having to execute it. Typically, this is done by building a model of data flow and control flow, then searching for potentially-vulnerable patterns that connect "sources" (origins of input) with "sinks" (destinations where the data interacts with external components, a lower layer such as the OS, etc.) Use industry standard APIs to implement locking mechanism. Chain: improper locking (CWE-667) leads to race condition (CWE-362), as exploited in the wild per CISA KEV. Attacker provides invalid address to a memory-reading function, causing a mutex to be unlocked twice function in OS kernel unlocks a mutex that was not previously locked, causing a panic or overwrite of arbitrary memory. Chain: OS kernel does not properly handle a failure of a function call (CWE-755), leading to an unlock of a resource that was not locked (CWE-832), with resultant crash. OS kernel performs an unlock in some incorrect circumstances, leading to panic. OS deadlock OS deadlock involving 3 separate functions deadlock in library deadlock triggered by packets that force collisions in a routing table read/write deadlock between web server and script web server deadlock involving multiple listening connections multiple simultaneous calls to the same function trigger deadlock. chain: other weakness leads to NULL pointer dereference (CWE-476) or deadlock (CWE-833). deadlock when an operation is performed on a resource while it is being removed. Deadlock in device driver triggered by using file handle of a related device. Deadlock when large number of small messages cannot be processed quickly enough. OS kernel has deadlock triggered by a signal during a core dump. Race condition leads to deadlock. Chain: array index error (CWE-129) leads to deadlock (CWE-833) Program can not execute when attacker obtains a mutex. Program can not execute when attacker obtains a lock on a critical output file. Program can not execute when attacker obtains a lock on a critical output file. Critical file can be opened with exclusive read access by user, preventing application of security policy. Possibly related to improper permissions, large-window race condition. Chain: predictable file names used for locking, allowing attacker to create the lock beforehand. Resultant from permissions and randomness. Chain: Lock files with predictable names. Resultant from randomness. Product does not check if it can write to a log file, allowing attackers to avoid logging by accessing the file using an exclusive lock. Overlaps unchecked error condition. This is not quite CWE-412, but close.

References


 

CPE

cpe start end
Configuration 1
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* >= 3.2 < 6.6.33
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* >= 6.7 < 6.8.12
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* >= 6.9 < 6.9.3


REMEDIATION


Patch

Url
https://git.kernel.org/stable/c/87bcbc9b7e0b43a69d44efa5f32f11e32d08fa6f
https://git.kernel.org/stable/c/accdd6b912c4219b8e056d1f1ad2e85bc66ee243
https://git.kernel.org/stable/c/c2e0c58b25a0a0c37ec643255558c5af4450c9f5
https://git.kernel.org/stable/c/d38625f71950e79e254515c5fc585552dad4b33e
https://git.kernel.org/stable/c/87bcbc9b7e0b43a69d44efa5f32f11e32d08fa6f
https://git.kernel.org/stable/c/accdd6b912c4219b8e056d1f1ad2e85bc66ee243
https://git.kernel.org/stable/c/c2e0c58b25a0a0c37ec643255558c5af4450c9f5
https://git.kernel.org/stable/c/d38625f71950e79e254515c5fc585552dad4b33e


EXPLOITS


Exploit-db.com

id description date
No known exploits

POC Github

Url
No known exploits

Other Nist (github, ...)

Url
No known exploits


CAPEC


Common Attack Pattern Enumerations and Classifications

id description severity
25 Forced Deadlock
High
26 Leveraging Race Conditions
High
27 Leveraging Race Conditions via Symbolic Links
High


MITRE


Techniques

id description
T1499.004 Endpoint Denial of Service: Application or System Exploitation
© 2022 The MITRE Corporation. This work is reproduced and distributed with the permission of The MITRE Corporation.

Mitigations

id description
M1037 Leverage services provided by Content Delivery Networks (CDN) or providers specializing in DoS mitigations to filter traffic upstream from services. Filter boundary traffic by blocking source addresses sourcing the attack, blocking ports that are being targeted, or blocking protocols being used for transport.
© 2022 The MITRE Corporation. Esta obra se reproduce y distribuye con el permiso de The MITRE Corporation.