Skip to content

Commit 7c6cd9e

Browse files
Yang Yingliangjfvogel
Yang Yingliang
authored andcommitted
ata: libata-transport: fix error handling in ata_tlink_add()
[ Upstream commit cf0816f ] In ata_tlink_add(), the return value of transport_add_device() is not checked. As a result, it causes null-ptr-deref while removing the module, because transport_remove_device() is called to remove the device that was not added. Unable to handle kernel NULL pointer dereference at virtual address 00000000000000d0 CPU: 33 PID: 13850 Comm: rmmod Kdump: loaded Tainted: G W 6.1.0-rc3+ #12 pstate: 60400009 (nZCv daif +PAN -UAO -TCO -DIT -SSBS BTYPE=--) pc : device_del+0x48/0x39c lr : device_del+0x44/0x39c Call trace: device_del+0x48/0x39c attribute_container_class_device_del+0x28/0x40 transport_remove_classdev+0x60/0x7c attribute_container_device_trigger+0x118/0x120 transport_remove_device+0x20/0x30 ata_tlink_delete+0x88/0xb0 [libata] ata_tport_delete+0x2c/0x60 [libata] ata_port_detach+0x148/0x1b0 [libata] ata_pci_remove_one+0x50/0x80 [libata] ahci_remove_one+0x4c/0x8c [ahci] Fix this by checking and handling return value of transport_add_device() in ata_tlink_add(). Fixes: d902747 ("[libata] Add ATA transport class") Signed-off-by: Yang Yingliang <[email protected]> Signed-off-by: Damien Le Moal <[email protected]> Signed-off-by: Sasha Levin <[email protected]> (cherry picked from commit 67b219314628b90b3a314528e177335b0cd5c70b) Signed-off-by: Jack Vogel <[email protected]>
1 parent 2bd0922 commit 7c6cd9e

File tree

1 file changed

+4
-1
lines changed

1 file changed

+4
-1
lines changed

drivers/ata/libata-transport.c

+4-1
Original file line numberDiff line numberDiff line change
@@ -428,7 +428,9 @@ int ata_tlink_add(struct ata_link *link)
428428
goto tlink_err;
429429
}
430430

431-
transport_add_device(dev);
431+
error = transport_add_device(dev);
432+
if (error)
433+
goto tlink_transport_err;
432434
transport_configure_device(dev);
433435

434436
ata_for_each_dev(ata_dev, link, ALL) {
@@ -443,6 +445,7 @@ int ata_tlink_add(struct ata_link *link)
443445
ata_tdev_delete(ata_dev);
444446
}
445447
transport_remove_device(dev);
448+
tlink_transport_err:
446449
device_del(dev);
447450
tlink_err:
448451
transport_destroy_device(dev);

0 commit comments

Comments
 (0)