mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-26 20:44:32 +08:00
pcmcia: cs: fix possible hung task and memory leak pccardd()
[ Upstream commite3ea1b4847
] If device_register() returns error in pccardd(), it leads two issues: 1. The socket_released has never been completed, it will block pcmcia_unregister_socket(), because of waiting for completion of socket_released. 2. The device name allocated by dev_set_name() is leaked. Fix this two issues by calling put_device() when device_register() fails. socket_released can be completed in pcmcia_release_socket(), the name can be freed in kobject_cleanup(). Fixes:1da177e4c3
("Linux-2.6.12-rc2") Signed-off-by: Yang Yingliang <yangyingliang@huawei.com> Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
b3eaa0d43c
commit
24e73ab542
@ -605,6 +605,7 @@ static int pccardd(void *__skt)
|
||||
dev_warn(&skt->dev, "PCMCIA: unable to register socket\n");
|
||||
skt->thread = NULL;
|
||||
complete(&skt->thread_done);
|
||||
put_device(&skt->dev);
|
||||
return 0;
|
||||
}
|
||||
ret = pccard_sysfs_add_socket(&skt->dev);
|
||||
|
Loading…
Reference in New Issue
Block a user