CVE-2024-56670

Source
https://cve.org/CVERecord?id=CVE-2024-56670
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2024-56670.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2024-56670
Downstream
Related
Published
2024-12-27T15:06:31.611Z
Modified
2026-05-28T03:54:56.175046724Z
Severity
  • 5.5 (Medium) CVSS_V3 - CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H CVSS Calculator
Summary
usb: gadget: u_serial: Fix the issue that gs_start_io crashed due to accessing null pointer
Details

In the Linux kernel, the following vulnerability has been resolved:

usb: gadget: userial: Fix the issue that gsstart_io crashed due to accessing null pointer

Considering that in some extreme cases, when userial driver is accessed by multiple threads, Thread A is executing the open operation and calling the gsopen, Thread B is executing the disconnect operation and calling the gserialdisconnect function,The port->portusb pointer will be set to NULL.

E.g. Thread A Thread B gsopen() gadgetunbinddriver() gsstartio() compositedisconnect() gsstartrx() gserialdisconnect() ... ... spinunlock(&port->portlock) status = usbepqueue() spinlock(&port->portlock) spinlock(&port->portlock) port->portusb = NULL gsfreerequests(port->portusb->in) spinunlock(&port->port_lock) Crash

This causes thread A to access a null pointer (port->portusb is null) when calling the gsfree_requests function, causing a crash.

If portusb is NULL, the release request will be skipped as it will be done by gserialdisconnect.

So add a null pointer check to gsstartio before attempting to access the value of the pointer port->port_usb.

Call trace: gsstartio+0x164/0x25c gsopen+0x108/0x13c ttyopen+0x314/0x638 chrdevopen+0x1b8/0x258 dodentryopen+0x2c4/0x700 vfsopen+0x2c/0x3c pathopenat+0xa64/0xc60 dofilpopen+0xb8/0x164 dosys_openat2+0x84/0xf0 __arm64sysopenat+0x70/0x9c invokesyscall+0x58/0x114 el0svccommon+0x80/0xe0 doel0svc+0x1c/0x28 el0svc+0x38/0x68

Database specific
{
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2024/56xxx/CVE-2024-56670.json",
    "cna_assigner": "Linux"
}
References

Affected packages

Git / git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git

Affected ranges

Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
c1dca562be8ada614ef193aa246c6f8705bcd6b9
Fixed
4efdfdc32d8d6307f968cd99f1db64468471bab1
Fixed
28b3c03a6790de1f6f2683919ad657840f0f0f58
Fixed
1247e1df086aa6c17ab53cd1bedce70dd7132765
Fixed
c83213b6649d22656b3a4e92544ceeea8a2c6c07
Fixed
8ca07a3d18f39b1669927ef536e485787e856df6
Fixed
dd6b0ca6025f64ccb465a6a3460c5b0307ed9c44
Fixed
4cfbca86f6a8b801f3254e0e3c8f2b1d2d64be2b

Database specific

source
"https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2024-56670.json"

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
2.6.27
Fixed
5.4.288
Type
ECOSYSTEM
Events
Introduced
5.5.0
Fixed
5.10.232
Type
ECOSYSTEM
Events
Introduced
5.11.0
Fixed
5.15.175
Type
ECOSYSTEM
Events
Introduced
5.16.0
Fixed
6.1.121
Type
ECOSYSTEM
Events
Introduced
6.2.0
Fixed
6.6.67
Type
ECOSYSTEM
Events
Introduced
6.7.0
Fixed
6.12.6

Database specific

source
"https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2024-56670.json"