CVE-2022-50542

critical

Description

In the Linux kernel, the following vulnerability has been resolved: media: si470x: Fix use-after-free in si470x_int_in_callback() syzbot reported use-after-free in si470x_int_in_callback() [1]. This indicates that urb->context, which contains struct si470x_device object, is freed when si470x_int_in_callback() is called. The cause of this issue is that si470x_int_in_callback() is called for freed urb. si470x_usb_driver_probe() calls si470x_start_usb(), which then calls usb_submit_urb() and si470x_start(). If si470x_start_usb() fails, si470x_usb_driver_probe() doesn't kill urb, but it just frees struct si470x_device object, as depicted below: si470x_usb_driver_probe() ... si470x_start_usb() ... usb_submit_urb() retval = si470x_start() return retval if (retval < 0) free struct si470x_device object, but don't kill urb This patch fixes this issue by killing urb when si470x_start_usb() fails and urb is submitted. If si470x_start_usb() fails and urb is not submitted, i.e. submitting usb fails, it just frees struct si470x_device object.

References

https://git.kernel.org/stable/c/92b0888398e4ba51d93b618a6506781f4e3879c9

https://git.kernel.org/stable/c/8c6151b8e8dd2d98ad2cd725d26d1e103d989891

https://git.kernel.org/stable/c/7d21e0b1b41b21d628bf2afce777727bd4479aa5

https://git.kernel.org/stable/c/6c8aee0c8fcc6dda94315f7908e8fa9bc75abe75

https://git.kernel.org/stable/c/63648a7bd1a7599bcc2040a6d1792363ae4c2e1b

https://git.kernel.org/stable/c/52f54fe78cca24850a30865037250f63eb3d5bf7

https://git.kernel.org/stable/c/1c6447d0fc68650e51586dde79b5090d9d77f13a

https://git.kernel.org/stable/c/146bd005ebb01ae190c22af050cb98623958c373

https://git.kernel.org/stable/c/0ca298d548461d29615f9a2b1309e8dcf4a352c6

Details

Source: Mitre, NVD

Published: 2025-10-07

Updated: 2025-10-08

Risk Information

CVSS v2

Base Score: 7.5

Vector: CVSS2#AV:N/AC:L/Au:N/C:P/I:P/A:P

Severity: High

CVSS v3

Base Score: 9.1

Vector: CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:H/A:H

Severity: Critical

EPSS

EPSS: 0.00033