CVE-2024-38633

Source
https://nvd.nist.gov/vuln/detail/CVE-2024-38633
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2024-38633.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2024-38633
Downstream
Related
Published
2024-06-21T10:18:22.905Z
Modified
2025-11-26T19:34:09.415876Z
Summary
serial: max3100: Update uart_driver_registered on driver removal
Details

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

serial: max3100: Update uartdriverregistered on driver removal

The removal of the last MAX3100 device triggers the removal of the driver. However, code doesn't update the respective global variable and after insmod — rmmod — insmod cycle the kernel oopses:

max3100 spi-PRP0001:01: max3100probe: adding port 0 BUG: kernel NULL pointer dereference, address: 0000000000000408 ... RIP: 0010:serialcoreregisterport+0xa0/0x840 ... max3100probe+0x1b6/0x280 [max3100] spiprobe+0x8d/0xb0

Update the actual state so next time UART driver will be registered again.

Hugo also noticed, that the error path in the probe also affected by having the variable set, and not cleared. Instead of clearing it move the assignment after the successfull uartregisterdriver() call.

Database specific
{
    "cna_assigner": "Linux",
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/blob/9c3874e559580d6c6ec8d449812ac11277724770/cves/2024/38xxx/CVE-2024-38633.json"
}
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
7831d56b0a3544cbb6f82f76c34ca95e24d5b676
Fixed
21a61a7fbcfdd3493cede43ebc7c4dfae2147a8b
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
7831d56b0a3544cbb6f82f76c34ca95e24d5b676
Fixed
9db4222ed8cd3e50b81c8b910ae74c26427a4003
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
7831d56b0a3544cbb6f82f76c34ca95e24d5b676
Fixed
e8e2a4339decad7e59425b594a98613402652d72
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
7831d56b0a3544cbb6f82f76c34ca95e24d5b676
Fixed
361a92c9038e8c8c3996f8eeaa14522a8ad90752
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
7831d56b0a3544cbb6f82f76c34ca95e24d5b676
Fixed
b6eb7aff23e05f362e8c9b560f6ac5e727b70e00
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
7831d56b0a3544cbb6f82f76c34ca95e24d5b676
Fixed
e8a10089eddba40d4b2080c9d3fc2d2b2488f762
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
7831d56b0a3544cbb6f82f76c34ca95e24d5b676
Fixed
fa84ca78b048dfb00df0ef446f5c35e0a98ca6a0
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
7831d56b0a3544cbb6f82f76c34ca95e24d5b676
Fixed
712a1fcb38dc7cac6da63ee79a88708fbf9c45ec

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
2.6.30
Fixed
4.19.316
Type
ECOSYSTEM
Events
Introduced
4.20.0
Fixed
5.4.278
Type
ECOSYSTEM
Events
Introduced
5.5.0
Fixed
5.10.219
Type
ECOSYSTEM
Events
Introduced
5.11.0
Fixed
5.15.161
Type
ECOSYSTEM
Events
Introduced
5.16.0
Fixed
6.1.93
Type
ECOSYSTEM
Events
Introduced
6.2.0
Fixed
6.6.33
Type
ECOSYSTEM
Events
Introduced
6.7.0
Fixed
6.9.4