CVE-2021-47549
Severity CVSS v4.0:
Pending analysis
Type:
CWE-416
Use After Free
Publication date:
24/05/2024
Last modified:
07/01/2025
Description
In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
sata_fsl: fix UAF in sata_fsl_port_stop when rmmod sata_fsl<br />
<br />
When the `rmmod sata_fsl.ko` command is executed in the PPC64 GNU/Linux,<br />
a bug is reported:<br />
==================================================================<br />
BUG: Unable to handle kernel data access on read at 0x80000800805b502c<br />
Oops: Kernel access of bad area, sig: 11 [#1]<br />
NIP [c0000000000388a4] .ioread32+0x4/0x20<br />
LR [80000000000c6034] .sata_fsl_port_stop+0x44/0xe0 [sata_fsl]<br />
Call Trace:<br />
.free_irq+0x1c/0x4e0 (unreliable)<br />
.ata_host_stop+0x74/0xd0 [libata]<br />
.release_nodes+0x330/0x3f0<br />
.device_release_driver_internal+0x178/0x2c0<br />
.driver_detach+0x64/0xd0<br />
.bus_remove_driver+0x70/0xf0<br />
.driver_unregister+0x38/0x80<br />
.platform_driver_unregister+0x14/0x30<br />
.fsl_sata_driver_exit+0x18/0xa20 [sata_fsl]<br />
.__se_sys_delete_module+0x1ec/0x2d0<br />
.system_call_exception+0xfc/0x1f0<br />
system_call_common+0xf8/0x200<br />
==================================================================<br />
<br />
The triggering of the BUG is shown in the following stack:<br />
<br />
driver_detach<br />
device_release_driver_internal<br />
__device_release_driver<br />
drv->remove(dev) --> platform_drv_remove/platform_remove<br />
drv->remove(dev) --> sata_fsl_remove<br />
iounmap(host_priv->hcr_base); data) --> ata_host_stop<br />
ap->ops->port_stop(ap) --> sata_fsl_port_stop<br />
ioread32(hcr_base + HCONTROL) ops->host_stop(host)<br />
<br />
The iounmap(host_priv->hcr_base) and kfree(host_priv) functions should<br />
not be executed in drv->remove. These functions should be executed in<br />
host_stop after port_stop. Therefore, we move these functions to the<br />
new function sata_fsl_host_stop and bind the new function to host_stop.
Impact
Base Score 3.x
7.80
Severity 3.x
HIGH
Vulnerable products and versions
CPE | From | Up to |
---|---|---|
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 2.6.24 (including) | 4.4.294 (excluding) |
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 4.5 (including) | 4.9.292 (excluding) |
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 4.10 (including) | 4.14.257 (excluding) |
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 4.15 (including) | 4.19.220 (excluding) |
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 4.20 (including) | 5.4.164 (excluding) |
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.5 (including) | 5.10.84 (excluding) |
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.11 (including) | 5.15.7 (excluding) |
cpe:2.3:o:linux:linux_kernel:5.16:rc1:*:*:*:*:*:* | ||
cpe:2.3:o:linux:linux_kernel:5.16:rc2:*:*:*:*:*:* | ||
cpe:2.3:o:linux:linux_kernel:5.16:rc3:*:*:*:*:*:* |
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/0769449b0a5eabc3545337217ae690e46673e73a
- https://git.kernel.org/stable/c/325ea49fc43cbc03a5e1e37de8f0ca6357ced4b1
- https://git.kernel.org/stable/c/4a46b2f5dce02539e88a300800812bd24a45e097
- https://git.kernel.org/stable/c/6c8ad7e8cf29eb55836e7a0215f967746ab2b504
- https://git.kernel.org/stable/c/77393806c76b6b44f1c44bd957788c8bd9152c45
- https://git.kernel.org/stable/c/91ba94d3f7afca195b224f77a72044fbde1389ce
- https://git.kernel.org/stable/c/adf098e2a8a1e1fc075d6a5ba2edd13cf7189082
- https://git.kernel.org/stable/c/cdcd80292106df5cda325426e96495503e41f947
- https://git.kernel.org/stable/c/0769449b0a5eabc3545337217ae690e46673e73a
- https://git.kernel.org/stable/c/325ea49fc43cbc03a5e1e37de8f0ca6357ced4b1
- https://git.kernel.org/stable/c/4a46b2f5dce02539e88a300800812bd24a45e097
- https://git.kernel.org/stable/c/6c8ad7e8cf29eb55836e7a0215f967746ab2b504
- https://git.kernel.org/stable/c/77393806c76b6b44f1c44bd957788c8bd9152c45
- https://git.kernel.org/stable/c/91ba94d3f7afca195b224f77a72044fbde1389ce
- https://git.kernel.org/stable/c/adf098e2a8a1e1fc075d6a5ba2edd13cf7189082
- https://git.kernel.org/stable/c/cdcd80292106df5cda325426e96495503e41f947