CVE-2024-47141 Information

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;

Reference

https://git.kernel.org/stable/c/2da32aed4a97ca1d70fb8b77926f72f30ce5fb4b https://git.kernel.org/stable/c/5a3e85c3c397c781393ea5fb2f45b1f60f8a4e6e https://git.kernel.org/stable/c/c11e2ec9a780f54982a187ee10ffd1b810715c85

Share on: