All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] power: supply: fix missing device_del() in __power_supply_register()
@ 2022-12-02  9:42 Yang Yingliang
  2022-12-03  0:45 ` Sebastian Reichel
  0 siblings, 1 reply; 2+ messages in thread
From: Yang Yingliang @ 2022-12-02  9:42 UTC (permalink / raw)
  To: sre, rafael.j.wysocki, swboyd; +Cc: linux-pm, yangyingliang

I got the a UAF and some warning reports while doing fault injection test:

==================================================================
BUG: KASAN: use-after-free in power_supply_uevent+0x59/0x190
Read of size 8 at addr ffff8881092c3c58 by task systemd-udevd/268

CPU: 3 PID: 268 Comm: systemd-udevd Tainted: G                 N 6.1.0-rc3+
rt1719: probe of 0-0043 failed with error -17
Call Trace:
 <TASK>
 kasan_report+0x90/0x190
 power_supply_uevent+0x59/0x190
 dev_uevent+0x1c8/0x3d0
 uevent_show+0x10f/0x1c0

Allocated by task 253:
 __kasan_kmalloc+0x7e/0x90
 __kmalloc_node_track_caller+0x55/0x1b0
 devm_kmalloc+0x5e/0x110
 rt1719_probe+0xdf/0x770 [rt1719]

Freed by task 253:
 kasan_save_free_info+0x2a/0x50
 __kasan_slab_free+0x102/0x190
 __kmem_cache_free+0xca/0x400
 release_nodes+0x78/0xa0
 devres_release_group+0x171/0x200
==================================================================

sysfs: cannot create duplicate filename '/class/power_supply/rt1719-source-psy-0-0043'
CPU: 3 PID: 1140 Comm: 89-i2c-rt1719 Tainted: G    B   W        N 6.1.0-rc3+
Call Trace:
 <TASK>
 dump_stack_lvl+0x67/0x83
 sysfs_warn_dup.cold.3+0x1c/0x28
 sysfs_do_create_link_sd.isra.2+0x11d/0x130
 sysfs_create_link+0x4c/0x80
 device_add+0x55a/0x10f0
 __power_supply_register+0x863/0xae0
 devm_power_supply_register+0x5f/0xb0

device_add() is called before device_init_wakeup(), if device_init_wakeup()
fails, device_del() needs be called.

Leak of device in sysfs, it also causes UAF problem:

CPU A
rt1719_probe()			|CPU B
  //desc is allocated by driver	|
  devm_kmalloc()		|
  __power_supply_register()	|
    psy->desc = desc;		|
  //desc is freed		|
  release_nodes()		|
				|power_supply_uevent()
				|  psy = dev_get_drvdata(dev);
				|  add_uevent_var(psy->desc->name) <-- UAF

So move device_del() after the error label wakeup_init_failed to fix this leak.

Fixes: 828802228485 ("power: supply: Init device wakeup after device_add()")
Signed-off-by: Yang Yingliang <yangyingliang@huawei.com>
---
 drivers/power/supply/power_supply_core.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/drivers/power/supply/power_supply_core.c b/drivers/power/supply/power_supply_core.c
index 4b5fb172fa99..9bae94d2ea3a 100644
--- a/drivers/power/supply/power_supply_core.c
+++ b/drivers/power/supply/power_supply_core.c
@@ -1387,8 +1387,8 @@ __power_supply_register(struct device *parent,
 register_cooler_failed:
 	psy_unregister_thermal(psy);
 register_thermal_failed:
-	device_del(dev);
 wakeup_init_failed:
+	device_del(dev);
 device_add_failed:
 check_supplies_failed:
 dev_set_name_failed:
-- 
2.25.1


^ permalink raw reply related	[flat|nested] 2+ messages in thread

* Re: [PATCH] power: supply: fix missing device_del() in __power_supply_register()
  2022-12-02  9:42 [PATCH] power: supply: fix missing device_del() in __power_supply_register() Yang Yingliang
@ 2022-12-03  0:45 ` Sebastian Reichel
  0 siblings, 0 replies; 2+ messages in thread
From: Sebastian Reichel @ 2022-12-03  0:45 UTC (permalink / raw)
  To: Yang Yingliang; +Cc: rafael.j.wysocki, swboyd, linux-pm

[-- Attachment #1: Type: text/plain, Size: 305 bytes --]

Hi,

On Fri, Dec 02, 2022 at 05:42:39PM +0800, Yang Yingliang wrote:
> I got the a UAF and some warning reports while doing fault injection test:
> ...

https://git.kernel.org/pub/scm/linux/kernel/git/sre/linux-power-supply.git/commit/?h=for-next&id=5b79480ce1978864ac3f06f2134dfa3b6691fe74

-- Sebastian

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 833 bytes --]

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2022-12-03  0:53 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-12-02  9:42 [PATCH] power: supply: fix missing device_del() in __power_supply_register() Yang Yingliang
2022-12-03  0:45 ` Sebastian Reichel

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.