CVE-2023-52570: Vulnerability in Linux Linux
In the Linux kernel, the following vulnerability has been resolved: vfio/mdev: Fix a null-ptr-deref bug for mdev_unregister_parent() Inject fault while probing mdpy.ko, if kstrdup() of create_dir() fails in kobject_add_internal() in kobject_init_and_add() in mdev_type_add() in parent_create_sysfs_files(), it will return 0 and probe successfully. And when rmmod mdpy.ko, the mdpy_dev_exit() will call mdev_unregister_parent(), the mdev_type_remove() may traverse uninitialized parent->types[i] in parent_remove_sysfs_files(), and it will cause below null-ptr-deref. If mdev_type_add() fails, return the error code and kset_unregister() to fix the issue. general protection fault, probably for non-canonical address 0xdffffc0000000002: 0000 [#1] PREEMPT SMP KASAN KASAN: null-ptr-deref in range [0x0000000000000010-0x0000000000000017] CPU: 2 PID: 10215 Comm: rmmod Tainted: G W N 6.6.0-rc2+ #20 Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.15.0-1 04/01/2014 RIP: 0010:__kobject_del+0x62/0x1c0 Code: 48 89 fa 48 c1 ea 03 80 3c 02 00 0f 85 51 01 00 00 48 b8 00 00 00 00 00 fc ff df 48 8b 6b 28 48 8d 7d 10 48 89 fa 48 c1 ea 03 <80> 3c 02 00 0f 85 24 01 00 00 48 8b 75 10 48 89 df 48 8d 6b 3c e8 RSP: 0018:ffff88810695fd30 EFLAGS: 00010202 RAX: dffffc0000000000 RBX: ffffffffa0270268 RCX: 0000000000000000 RDX: 0000000000000002 RSI: 0000000000000004 RDI: 0000000000000010 RBP: 0000000000000000 R08: 0000000000000001 R09: ffffed10233a4ef1 R10: ffff888119d2778b R11: 0000000063666572 R12: 0000000000000000 R13: fffffbfff404e2d4 R14: dffffc0000000000 R15: ffffffffa0271660 FS: 00007fbc81981540(0000) GS:ffff888119d00000(0000) knlGS:0000000000000000 CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033 CR2: 00007fc14a142dc0 CR3: 0000000110a62003 CR4: 0000000000770ee0 DR0: ffffffff8fb0bce8 DR1: ffffffff8fb0bce9 DR2: ffffffff8fb0bcea DR3: ffffffff8fb0bceb DR6: 00000000fffe0ff0 DR7: 0000000000000600 PKRU: 55555554 Call Trace: <TASK> ? die_addr+0x3d/0xa0 ? exc_general_protection+0x144/0x220 ? asm_exc_general_protection+0x22/0x30 ? __kobject_del+0x62/0x1c0 kobject_del+0x32/0x50 parent_remove_sysfs_files+0xd6/0x170 [mdev] mdev_unregister_parent+0xfb/0x190 [mdev] ? mdev_register_parent+0x270/0x270 [mdev] ? find_module_all+0x9d/0xe0 mdpy_dev_exit+0x17/0x63 [mdpy] __do_sys_delete_module.constprop.0+0x2fa/0x4b0 ? module_flags+0x300/0x300 ? __fput+0x4e7/0xa00 do_syscall_64+0x35/0x80 entry_SYSCALL_64_after_hwframe+0x46/0xb0 RIP: 0033:0x7fbc813221b7 Code: 73 01 c3 48 8b 0d d1 8c 2c 00 f7 d8 64 89 01 48 83 c8 ff c3 66 2e 0f 1f 84 00 00 00 00 00 0f 1f 44 00 00 b8 b0 00 00 00 0f 05 <48> 3d 01 f0 ff ff 73 01 c3 48 8b 0d a1 8c 2c 00 f7 d8 64 89 01 48 RSP: 002b:00007ffe780e0648 EFLAGS: 00000206 ORIG_RAX: 00000000000000b0 RAX: ffffffffffffffda RBX: 00007ffe780e06a8 RCX: 00007fbc813221b7 RDX: 000000000000000a RSI: 0000000000000800 RDI: 000055e214df9b58 RBP: 000055e214df9af0 R08: 00007ffe780df5c1 R09: 0000000000000000 R10: 00007fbc8139ecc0 R11: 0000000000000206 R12: 00007ffe780e0870 R13: 00007ffe780e0ed0 R14: 000055e214df9260 R15: 000055e214df9af0 </TASK> Modules linked in: mdpy(-) mdev vfio_iommu_type1 vfio [last unloaded: mdpy] Dumping ftrace buffer: (ftrace buffer empty) ---[ end trace 0000000000000000 ]--- RIP: 0010:__kobject_del+0x62/0x1c0 Code: 48 89 fa 48 c1 ea 03 80 3c 02 00 0f 85 51 01 00 00 48 b8 00 00 00 00 00 fc ff df 48 8b 6b 28 48 8d 7d 10 48 89 fa 48 c1 ea 03 <80> 3c 02 00 0f 85 24 01 00 00 48 8b 75 10 48 89 df 48 8d 6b 3c e8 RSP: 0018:ffff88810695fd30 EFLAGS: 00010202 RAX: dffffc0000000000 RBX: ffffffffa0270268 RCX: 0000000000000000 RDX: 0000000000000002 RSI: 0000000000000004 RDI: 0000000000000010 RBP: 0000000000000000 R08: 0000000000000001 R09: ffffed10233a4ef1 R10: ffff888119d2778b R11: 0000000063666572 R12: 0000000000000000 R13: fffffbfff404e2d4 R14: dffffc0000000000 R15: ffffffffa0271660 FS: 00007fbc81981540(0000) GS:ffff888119d00000(000 ---truncated---
AI Analysis
Technical Summary
CVE-2023-52570 is a vulnerability identified in the Linux kernel, specifically within the vfio/mdev subsystem that handles mediated device (mdev) operations. The flaw arises from improper error handling during the registration and unregistration of mediated device parents. When the kernel module mdpy.ko is probed, if certain internal kernel functions such as kstrdup() or create_dir() fail during sysfs object creation (kobject_add_internal()), the probe incorrectly returns success (0) despite the failure. This leads to an uninitialized or partially initialized parent->types array. Later, when the mdpy.ko module is removed (rmmod), the cleanup function mdpy_dev_exit() calls mdev_unregister_parent(), which in turn calls mdev_type_remove(). This function attempts to traverse the uninitialized parent->types array, causing a null pointer dereference and triggering a kernel crash (general protection fault). The kernel logs show a KASAN (Kernel Address Sanitizer) detected null pointer dereference in __kobject_del(), confirming the memory safety violation. The root cause is a missing error return and cleanup in mdev_type_add() when sysfs object creation fails. The fix involves returning the error code properly and unregistering the kset to avoid leaving inconsistent state. This vulnerability can cause a denial of service (DoS) by crashing the kernel when the vulnerable module is removed. Exploitation requires loading and unloading the mdpy.ko module, which is part of the mediated device framework used in virtualization environments to share physical devices with virtual machines. There is no indication of privilege escalation or remote code execution. No CVSS score has been assigned yet, and no known exploits are reported in the wild as of the publication date (March 2, 2024).
Potential Impact
For European organizations, the primary impact of CVE-2023-52570 is a potential denial of service condition on Linux systems running kernels with the vulnerable vfio/mdev code and using the mdpy.ko module. This is particularly relevant for organizations employing virtualization technologies that utilize mediated devices for resource sharing, such as cloud service providers, data centers, and enterprises with private clouds or virtualized infrastructure. A kernel crash can disrupt critical services, cause downtime, and require system reboots, impacting availability and operational continuity. Although this vulnerability does not appear to allow privilege escalation or data compromise, the resulting instability could affect sensitive environments where uptime is critical, such as financial institutions, healthcare providers, and industrial control systems. Additionally, the complexity of the vulnerability means that only systems explicitly using the mediated device framework and the mdpy.ko module are at risk, limiting the scope but increasing the importance of targeted mitigation in affected environments.
Mitigation Recommendations
To mitigate CVE-2023-52570, European organizations should: 1) Apply the latest Linux kernel patches that address this vulnerability as soon as they become available from trusted sources or Linux distribution vendors. 2) Audit systems to identify the presence and use of the mdpy.ko module and the vfio/mdev mediated device framework, especially in virtualization hosts. 3) Where possible, disable or unload the mdpy.ko module if it is not required, reducing the attack surface. 4) Implement strict kernel module loading policies and monitoring to detect unauthorized or unexpected module insertions and removals. 5) For critical systems, consider employing kernel live patching solutions to apply fixes without downtime. 6) Maintain robust backup and recovery procedures to minimize impact in case of kernel crashes. 7) Monitor system logs for signs of kernel faults or crashes related to kobject or mdev operations to detect exploitation attempts early. These steps go beyond generic advice by focusing on the specific module and subsystem involved and emphasizing proactive detection and operational controls.
Affected Countries
Germany, France, United Kingdom, Netherlands, Sweden, Finland, Denmark, Ireland
CVE-2023-52570: Vulnerability in Linux Linux
Description
In the Linux kernel, the following vulnerability has been resolved: vfio/mdev: Fix a null-ptr-deref bug for mdev_unregister_parent() Inject fault while probing mdpy.ko, if kstrdup() of create_dir() fails in kobject_add_internal() in kobject_init_and_add() in mdev_type_add() in parent_create_sysfs_files(), it will return 0 and probe successfully. And when rmmod mdpy.ko, the mdpy_dev_exit() will call mdev_unregister_parent(), the mdev_type_remove() may traverse uninitialized parent->types[i] in parent_remove_sysfs_files(), and it will cause below null-ptr-deref. If mdev_type_add() fails, return the error code and kset_unregister() to fix the issue. general protection fault, probably for non-canonical address 0xdffffc0000000002: 0000 [#1] PREEMPT SMP KASAN KASAN: null-ptr-deref in range [0x0000000000000010-0x0000000000000017] CPU: 2 PID: 10215 Comm: rmmod Tainted: G W N 6.6.0-rc2+ #20 Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.15.0-1 04/01/2014 RIP: 0010:__kobject_del+0x62/0x1c0 Code: 48 89 fa 48 c1 ea 03 80 3c 02 00 0f 85 51 01 00 00 48 b8 00 00 00 00 00 fc ff df 48 8b 6b 28 48 8d 7d 10 48 89 fa 48 c1 ea 03 <80> 3c 02 00 0f 85 24 01 00 00 48 8b 75 10 48 89 df 48 8d 6b 3c e8 RSP: 0018:ffff88810695fd30 EFLAGS: 00010202 RAX: dffffc0000000000 RBX: ffffffffa0270268 RCX: 0000000000000000 RDX: 0000000000000002 RSI: 0000000000000004 RDI: 0000000000000010 RBP: 0000000000000000 R08: 0000000000000001 R09: ffffed10233a4ef1 R10: ffff888119d2778b R11: 0000000063666572 R12: 0000000000000000 R13: fffffbfff404e2d4 R14: dffffc0000000000 R15: ffffffffa0271660 FS: 00007fbc81981540(0000) GS:ffff888119d00000(0000) knlGS:0000000000000000 CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033 CR2: 00007fc14a142dc0 CR3: 0000000110a62003 CR4: 0000000000770ee0 DR0: ffffffff8fb0bce8 DR1: ffffffff8fb0bce9 DR2: ffffffff8fb0bcea DR3: ffffffff8fb0bceb DR6: 00000000fffe0ff0 DR7: 0000000000000600 PKRU: 55555554 Call Trace: <TASK> ? die_addr+0x3d/0xa0 ? exc_general_protection+0x144/0x220 ? asm_exc_general_protection+0x22/0x30 ? __kobject_del+0x62/0x1c0 kobject_del+0x32/0x50 parent_remove_sysfs_files+0xd6/0x170 [mdev] mdev_unregister_parent+0xfb/0x190 [mdev] ? mdev_register_parent+0x270/0x270 [mdev] ? find_module_all+0x9d/0xe0 mdpy_dev_exit+0x17/0x63 [mdpy] __do_sys_delete_module.constprop.0+0x2fa/0x4b0 ? module_flags+0x300/0x300 ? __fput+0x4e7/0xa00 do_syscall_64+0x35/0x80 entry_SYSCALL_64_after_hwframe+0x46/0xb0 RIP: 0033:0x7fbc813221b7 Code: 73 01 c3 48 8b 0d d1 8c 2c 00 f7 d8 64 89 01 48 83 c8 ff c3 66 2e 0f 1f 84 00 00 00 00 00 0f 1f 44 00 00 b8 b0 00 00 00 0f 05 <48> 3d 01 f0 ff ff 73 01 c3 48 8b 0d a1 8c 2c 00 f7 d8 64 89 01 48 RSP: 002b:00007ffe780e0648 EFLAGS: 00000206 ORIG_RAX: 00000000000000b0 RAX: ffffffffffffffda RBX: 00007ffe780e06a8 RCX: 00007fbc813221b7 RDX: 000000000000000a RSI: 0000000000000800 RDI: 000055e214df9b58 RBP: 000055e214df9af0 R08: 00007ffe780df5c1 R09: 0000000000000000 R10: 00007fbc8139ecc0 R11: 0000000000000206 R12: 00007ffe780e0870 R13: 00007ffe780e0ed0 R14: 000055e214df9260 R15: 000055e214df9af0 </TASK> Modules linked in: mdpy(-) mdev vfio_iommu_type1 vfio [last unloaded: mdpy] Dumping ftrace buffer: (ftrace buffer empty) ---[ end trace 0000000000000000 ]--- RIP: 0010:__kobject_del+0x62/0x1c0 Code: 48 89 fa 48 c1 ea 03 80 3c 02 00 0f 85 51 01 00 00 48 b8 00 00 00 00 00 fc ff df 48 8b 6b 28 48 8d 7d 10 48 89 fa 48 c1 ea 03 <80> 3c 02 00 0f 85 24 01 00 00 48 8b 75 10 48 89 df 48 8d 6b 3c e8 RSP: 0018:ffff88810695fd30 EFLAGS: 00010202 RAX: dffffc0000000000 RBX: ffffffffa0270268 RCX: 0000000000000000 RDX: 0000000000000002 RSI: 0000000000000004 RDI: 0000000000000010 RBP: 0000000000000000 R08: 0000000000000001 R09: ffffed10233a4ef1 R10: ffff888119d2778b R11: 0000000063666572 R12: 0000000000000000 R13: fffffbfff404e2d4 R14: dffffc0000000000 R15: ffffffffa0271660 FS: 00007fbc81981540(0000) GS:ffff888119d00000(000 ---truncated---
AI-Powered Analysis
Technical Analysis
CVE-2023-52570 is a vulnerability identified in the Linux kernel, specifically within the vfio/mdev subsystem that handles mediated device (mdev) operations. The flaw arises from improper error handling during the registration and unregistration of mediated device parents. When the kernel module mdpy.ko is probed, if certain internal kernel functions such as kstrdup() or create_dir() fail during sysfs object creation (kobject_add_internal()), the probe incorrectly returns success (0) despite the failure. This leads to an uninitialized or partially initialized parent->types array. Later, when the mdpy.ko module is removed (rmmod), the cleanup function mdpy_dev_exit() calls mdev_unregister_parent(), which in turn calls mdev_type_remove(). This function attempts to traverse the uninitialized parent->types array, causing a null pointer dereference and triggering a kernel crash (general protection fault). The kernel logs show a KASAN (Kernel Address Sanitizer) detected null pointer dereference in __kobject_del(), confirming the memory safety violation. The root cause is a missing error return and cleanup in mdev_type_add() when sysfs object creation fails. The fix involves returning the error code properly and unregistering the kset to avoid leaving inconsistent state. This vulnerability can cause a denial of service (DoS) by crashing the kernel when the vulnerable module is removed. Exploitation requires loading and unloading the mdpy.ko module, which is part of the mediated device framework used in virtualization environments to share physical devices with virtual machines. There is no indication of privilege escalation or remote code execution. No CVSS score has been assigned yet, and no known exploits are reported in the wild as of the publication date (March 2, 2024).
Potential Impact
For European organizations, the primary impact of CVE-2023-52570 is a potential denial of service condition on Linux systems running kernels with the vulnerable vfio/mdev code and using the mdpy.ko module. This is particularly relevant for organizations employing virtualization technologies that utilize mediated devices for resource sharing, such as cloud service providers, data centers, and enterprises with private clouds or virtualized infrastructure. A kernel crash can disrupt critical services, cause downtime, and require system reboots, impacting availability and operational continuity. Although this vulnerability does not appear to allow privilege escalation or data compromise, the resulting instability could affect sensitive environments where uptime is critical, such as financial institutions, healthcare providers, and industrial control systems. Additionally, the complexity of the vulnerability means that only systems explicitly using the mediated device framework and the mdpy.ko module are at risk, limiting the scope but increasing the importance of targeted mitigation in affected environments.
Mitigation Recommendations
To mitigate CVE-2023-52570, European organizations should: 1) Apply the latest Linux kernel patches that address this vulnerability as soon as they become available from trusted sources or Linux distribution vendors. 2) Audit systems to identify the presence and use of the mdpy.ko module and the vfio/mdev mediated device framework, especially in virtualization hosts. 3) Where possible, disable or unload the mdpy.ko module if it is not required, reducing the attack surface. 4) Implement strict kernel module loading policies and monitoring to detect unauthorized or unexpected module insertions and removals. 5) For critical systems, consider employing kernel live patching solutions to apply fixes without downtime. 6) Maintain robust backup and recovery procedures to minimize impact in case of kernel crashes. 7) Monitor system logs for signs of kernel faults or crashes related to kobject or mdev operations to detect exploitation attempts early. These steps go beyond generic advice by focusing on the specific module and subsystem involved and emphasizing proactive detection and operational controls.
Affected Countries
For access to advanced analysis and higher rate limits, contact root@offseq.com
Technical Details
- Data Version
- 5.1
- Assigner Short Name
- Linux
- Date Reserved
- 2024-03-02T21:55:42.567Z
- Cisa Enriched
- true
- Cvss Version
- null
- State
- PUBLISHED
Threat ID: 682d9831c4522896dcbe7cb1
Added to database: 5/21/2025, 9:09:05 AM
Last enriched: 7/1/2025, 10:25:41 AM
Last updated: 8/7/2025, 4:24:21 PM
Views: 14
Related Threats
CVE-2025-8878: CWE-94 Improper Control of Generation of Code ('Code Injection') in properfraction Paid Membership Plugin, Ecommerce, User Registration Form, Login Form, User Profile & Restrict Content – ProfilePress
MediumCVE-2025-8143: CWE-79 Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting') in pencidesign Soledad
MediumCVE-2025-8142: CWE-98 Improper Control of Filename for Include/Require Statement in PHP Program ('PHP Remote File Inclusion') in pencidesign Soledad
HighCVE-2025-8105: CWE-94 Improper Control of Generation of Code ('Code Injection') in pencidesign Soledad
HighCVE-2025-8719: CWE-79 Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting') in reubenthiessen Translate This gTranslate Shortcode
MediumActions
Updates to AI analysis are available only with a Pro account. Contact root@offseq.com for access.
External Links
Need enhanced features?
Contact root@offseq.com for Pro access with improved analysis and higher rate limits.