CVE-2023-52449
Severity CVSS v4.0:
Pending analysis
Type:
CWE-476
NULL Pointer Dereference
Publication date:
22/02/2024
Last modified:
04/11/2024
Description
In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
mtd: Fix gluebi NULL pointer dereference caused by ftl notifier<br />
<br />
If both ftl.ko and gluebi.ko are loaded, the notifier of ftl<br />
triggers NULL pointer dereference when trying to access<br />
‘gluebi->desc’ in gluebi_read().<br />
<br />
ubi_gluebi_init<br />
ubi_register_volume_notifier<br />
ubi_enumerate_volumes<br />
ubi_notify_all<br />
gluebi_notify nb->notifier_call()<br />
gluebi_create<br />
mtd_device_register<br />
mtd_device_parse_register<br />
add_mtd_device<br />
blktrans_notify_add not->add()<br />
ftl_add_mtd tr->add_mtd()<br />
scan_header<br />
mtd_read<br />
mtd_read_oob<br />
mtd_read_oob_std<br />
gluebi_read mtd->read()<br />
gluebi->desc - NULL<br />
<br />
Detailed reproduction information available at the Link [1],<br />
<br />
In the normal case, obtain gluebi->desc in the gluebi_get_device(),<br />
and access gluebi->desc in the gluebi_read(). However,<br />
gluebi_get_device() is not executed in advance in the<br />
ftl_add_mtd() process, which leads to NULL pointer dereference.<br />
<br />
The solution for the gluebi module is to run jffs2 on the UBI<br />
volume without considering working with ftl or mtdblock [2].<br />
Therefore, this problem can be avoided by preventing gluebi from<br />
creating the mtdblock device after creating mtd partition of the<br />
type MTD_UBIVOLUME.
Impact
Base Score 3.x
5.50
Severity 3.x
MEDIUM
Vulnerable products and versions
| CPE | From | Up to |
|---|---|---|
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 2.6.31 (including) | 4.19.306 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 4.20 (including) | 5.4.268 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.5.0 (including) | 5.10.209 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.11.0 (including) | 5.15.148 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.16.0 (including) | 6.1.75 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.2.0 (including) | 6.6.14 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.7.0 (including) | 6.7.2 (excluding) |
To consult the complete list of CPE names with products and versions, see this page
References to Advisories, Solutions, and Tools
- https://git.kernel.org/stable/c/001a3f59d8c914ef8273461d4bf495df384cc5f8
- https://git.kernel.org/stable/c/1bf4fe14e97cda621522eb2f28b0a4e87c5b0745
- https://git.kernel.org/stable/c/5389407bba1eab1266c6d83e226fb0840cb98dd5
- https://git.kernel.org/stable/c/a43bdc376deab5fff1ceb93dca55bcab8dbdc1d6
- https://git.kernel.org/stable/c/aeba358bcc8ffddf9b4a9bd0e5ec9eb338d46022
- https://git.kernel.org/stable/c/b36aaa64d58aaa2f2cbc8275e89bae76a2b6c3dc
- https://git.kernel.org/stable/c/cfd7c9d260dc0a3baaea05a122a19ab91e193c65
- https://git.kernel.org/stable/c/d8ac2537763b54d278b80b2b080e1652523c7d4c



