CVE-2024-47141

MEDIUM

Linux Kernel - Race Condition in Pinmux State Selection

Title source: llm
STIX 2.1

Description

In the Linux kernel, the following vulnerability has been resolved: pinmux: Use sequential access to access desc->pinmux data When two client of the same gpio call pinctrl_select_state() for the same functionality, we are seeing NULL pointer issue while accessing desc->mux_owner. Let's say two processes A, B executing in pin_request() for the same pin and process A updates the desc->mux_usecount but not yet updated the desc->mux_owner while process B see the desc->mux_usecount which got updated by A path and further executes strcmp and while accessing desc->mux_owner it crashes with NULL pointer. Serialize the access to mux related setting with a mutex lock. cpu0 (process A) cpu1(process B) pinctrl_select_state() { pinctrl_select_state() { pin_request() { pin_request() { ... .... } else { desc->mux_usecount++; desc->mux_usecount && strcmp(desc->mux_owner, owner)) { if (desc->mux_usecount > 1) return 0; desc->mux_owner = owner; } }

Scores

CVSS v3 5.5
EPSS 0.0016
EPSS Percentile 5.9%
Attack Vector LOCAL
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H

CISA SSVC

Vulnrichment
Exploitation none
Automatable no
Technical Impact partial

Details

CWE
CWE-667
Status published
Products (11)
linux/Kernel 3.10.0 - 6.6.66linux
linux/Kernel 6.7.0 - 6.12.5linux
Linux/Linux < 3.10
Linux/Linux 3.10
Linux/Linux 42fed7ba44e4e8c1fb27b28ad14490cb1daff3c7 - 2da32aed4a97ca1d70fb8b77926f72f30ce5fb4b
Linux/Linux 42fed7ba44e4e8c1fb27b28ad14490cb1daff3c7 - 5a3e85c3c397c781393ea5fb2f45b1f60f8a4e6e
Linux/Linux 42fed7ba44e4e8c1fb27b28ad14490cb1daff3c7 - c11e2ec9a780f54982a187ee10ffd1b810715c85
Linux/Linux 6.12.5 - 6.12.*
Linux/Linux 6.13
Linux/Linux 6.6.66 - 6.6.*
... and 1 more
Published Jan 11, 2025
Tracked Since Feb 18, 2026