CVE-2022-50578
Gravedad:
Pendiente de análisis
Tipo:
No Disponible / Otro tipo
Fecha de publicación:
22/10/2025
Última modificación:
22/10/2025
Descripción
*** Pendiente de traducción *** In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
class: fix possible memory leak in __class_register()<br />
<br />
If class_add_groups() returns error, the &#39;cp->subsys&#39; need be<br />
unregister, and the &#39;cp&#39; need be freed.<br />
<br />
We can not call kset_unregister() here, because the &#39;cls&#39; will<br />
be freed in callback function class_release() and it&#39;s also<br />
freed in caller&#39;s error path, it will cause double free.<br />
<br />
So fix this by calling kobject_del() and kfree_const(name) to<br />
cleanup kobject. Besides, call kfree() to free the &#39;cp&#39;.<br />
<br />
Fault injection test can trigger this:<br />
<br />
unreferenced object 0xffff888102fa8190 (size 8):<br />
comm "modprobe", pid 502, jiffies 4294906074 (age 49.296s)<br />
hex dump (first 8 bytes):<br />
70 6b 74 63 64 76 64 00 pktcdvd.<br />
backtrace:<br />
[] __kmalloc_track_caller+0x1ae/0x320<br />
[] kstrdup+0x3a/0x70<br />
[] kstrdup_const+0x68/0x80<br />
[] kvasprintf_const+0x10b/0x190<br />
[] kobject_set_name_vargs+0x56/0x150<br />
[] kobject_set_name+0xab/0xe0<br />
[] __class_register+0x15c/0x49a<br />
<br />
unreferenced object 0xffff888037274000 (size 1024):<br />
comm "modprobe", pid 502, jiffies 4294906074 (age 49.296s)<br />
hex dump (first 32 bytes):<br />
00 40 27 37 80 88 ff ff 00 40 27 37 80 88 ff ff .@&#39;7.....@&#39;7....<br />
00 00 00 00 ad 4e ad de ff ff ff ff 00 00 00 00 .....N..........<br />
backtrace:<br />
[] kmem_cache_alloc_trace+0x17c/0x2f0<br />
[] __class_register+0x86/0x49a
Impacto
Referencias a soluciones, herramientas e información
- https://git.kernel.org/stable/c/18a7200646958cf8e1b8a933de08122fc50676cd
- https://git.kernel.org/stable/c/3bb9c92c27624ad076419a70f2b1a30cd1f8bbbd
- https://git.kernel.org/stable/c/3e0efc3f3f5e5c73996782f8db69963e501bb878
- https://git.kernel.org/stable/c/417ef049e3fd3b0d2593c1d5ffa3d0d5d0a018a7
- https://git.kernel.org/stable/c/4efa5443817c1b6de22d401aeca5b2481e835f8c
- https://git.kernel.org/stable/c/8c3e8a6bdb5253b97ad532570f8b5db5f7a06407
- https://git.kernel.org/stable/c/abaedb68a769e6bf36836b55a2f49b531c5f3f7b
- https://git.kernel.org/stable/c/e764ad5918a099ebeb909ccff83893a714e497e1



