Goal Reached Thanks to every supporter — we hit 100%!

Goal: 1000 CNY · Raised: 1000 CNY

100.0%

CVE-2024-26596— net: dsa: fix netdev_priv() dereference before check on non-DSA netdevice events

EPSS 0.02% · P4
Get alerts for future matching vulnerabilitiesLog in to subscribe

I. Basic Information for CVE-2024-26596

Vulnerability Information

Have questions about the vulnerability? See if Shenlong's analysis helps!
View Shenlong Deep Dive ↗

Although we use advanced large model technology, its output may still contain inaccurate or outdated information.Shenlong tries to ensure data accuracy, but please verify and judge based on the actual situation.

Vulnerability Title
net: dsa: fix netdev_priv() dereference before check on non-DSA netdevice events
Source: NVD (National Vulnerability Database)
Vulnerability Description
In the Linux kernel, the following vulnerability has been resolved: net: dsa: fix netdev_priv() dereference before check on non-DSA netdevice events After the blamed commit, we started doing this dereference for every NETDEV_CHANGEUPPER and NETDEV_PRECHANGEUPPER event in the system. static inline struct dsa_port *dsa_user_to_port(const struct net_device *dev) { struct dsa_user_priv *p = netdev_priv(dev); return p->dp; } Which is obviously bogus, because not all net_devices have a netdev_priv() of type struct dsa_user_priv. But struct dsa_user_priv is fairly small, and p->dp means dereferencing 8 bytes starting with offset 16. Most drivers allocate that much private memory anyway, making our access not fault, and we discard the bogus data quickly afterwards, so this wasn't caught. But the dummy interface is somewhat special in that it calls alloc_netdev() with a priv size of 0. So every netdev_priv() dereference is invalid, and we get this when we emit a NETDEV_PRECHANGEUPPER event with a VLAN as its new upper: $ ip link add dummy1 type dummy $ ip link add link dummy1 name dummy1.100 type vlan id 100 [ 43.309174] ================================================================== [ 43.316456] BUG: KASAN: slab-out-of-bounds in dsa_user_prechangeupper+0x30/0xe8 [ 43.323835] Read of size 8 at addr ffff3f86481d2990 by task ip/374 [ 43.330058] [ 43.342436] Call trace: [ 43.366542] dsa_user_prechangeupper+0x30/0xe8 [ 43.371024] dsa_user_netdevice_event+0xb38/0xee8 [ 43.375768] notifier_call_chain+0xa4/0x210 [ 43.379985] raw_notifier_call_chain+0x24/0x38 [ 43.384464] __netdev_upper_dev_link+0x3ec/0x5d8 [ 43.389120] netdev_upper_dev_link+0x70/0xa8 [ 43.393424] register_vlan_dev+0x1bc/0x310 [ 43.397554] vlan_newlink+0x210/0x248 [ 43.401247] rtnl_newlink+0x9fc/0xe30 [ 43.404942] rtnetlink_rcv_msg+0x378/0x580 Avoid the kernel oops by dereferencing after the type check, as customary.
Source: NVD (National Vulnerability Database)
CVSS Information
N/A
Source: NVD (National Vulnerability Database)
Vulnerability Type
N/A
Source: NVD (National Vulnerability Database)
Vulnerability Title
Linux kernel 安全漏洞
Source: CNNVD (China National Vulnerability Database)
Vulnerability Description
Linux kernel是美国Linux基金会的开源操作系统Linux所使用的内核。 Linux Kernel 存在安全漏洞,该漏洞源于 netdev_priv() 方法存在取消引用问题。
Source: CNNVD (China National Vulnerability Database)
CVSS Information
N/A
Source: CNNVD (China National Vulnerability Database)
Vulnerability Type
N/A
Source: CNNVD (China National Vulnerability Database)

Affected Products

VendorProductAffected VersionsCPESubscribe
LinuxLinux 4c3f80d22b2eca911143ce656fa45c4699ff5bf4 ~ 9e9953f5e4d6d11a9dad56fdee307bb923302809 -
LinuxLinux 6.1 -

II. Public POCs for CVE-2024-26596

#POC DescriptionSource LinkShenlong Link
AI-Generated POCPremium

No public POC found.

Login to generate AI POC

III. Intelligence Information for CVE-2024-26596

登录查看更多情报信息。

Same Patch Batch · Linux · 2024-02-23 · 19 CVEs total

CVE-2023-52459media: v4l: async: Fix duplicated list deletion
CVE-2024-26593i2c: i801: Fix block process call transactions
CVE-2024-26594ksmbd: validate mech token in session setup
CVE-2023-52453hisi_acc_vfio_pci: Update migration data pointer correctly on saving/resume
CVE-2023-52455iommu: Don't reserve 0-length IOVA region
CVE-2023-52454nvmet-tcp: Fix a kernel panic when host sends an invalid H2C PDU length
CVE-2023-52456serial: imx: fix tx statemachine deadlock
CVE-2023-52458block: add check that partition length needs to be aligned with block size
CVE-2023-52457serial: 8250: omap: Don't skip resource freeing if pm_runtime_resume_and_get() failed
CVE-2024-26598KVM: arm64: vgic-its: Avoid potential UAF in LPI translation cache
CVE-2023-52461drm/sched: Fix bounds limiting when given a malformed entity
CVE-2023-52460drm/amd/display: Fix NULL pointer dereference at hibernate
CVE-2023-52462bpf: fix check for attempt to corrupt spilled pointer
CVE-2023-52464EDAC/thunderx: Fix possible out-of-bounds string access
CVE-2023-52463efivarfs: force RO when remounting if SetVariable is not supported
CVE-2024-26595mlxsw: spectrum_acl_tcam: Fix NULL pointer dereference in error path
CVE-2024-26597net: qualcomm: rmnet: fix global oob in rmnet_policy
CVE-2024-26599pwm: Fix out-of-bounds access in of_pwm_single_xlate()

IV. Related Vulnerabilities

V. Comments for CVE-2024-26596

No comments yet


Leave a comment