CVE-2024-35839
Severity CVSS v4.0:
Pending analysis
Type:
Unavailable / Other
Publication date:
17/05/2024
Last modified:
24/09/2025
Description
In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
netfilter: bridge: replace physindev with physinif in nf_bridge_info<br />
<br />
An skb can be added to a neigh->arp_queue while waiting for an arp<br />
reply. Where original skb&#39;s skb->dev can be different to neigh&#39;s<br />
neigh->dev. For instance in case of bridging dnated skb from one veth to<br />
another, the skb would be added to a neigh->arp_queue of the bridge.<br />
<br />
As skb->dev can be reset back to nf_bridge->physindev and used, and as<br />
there is no explicit mechanism that prevents this physindev from been<br />
freed under us (for instance neigh_flush_dev doesn&#39;t cleanup skbs from<br />
different device&#39;s neigh queue) we can crash on e.g. this stack:<br />
<br />
arp_process<br />
neigh_update<br />
skb = __skb_dequeue(&neigh->arp_queue)<br />
neigh_resolve_output(..., skb)<br />
...<br />
br_nf_dev_xmit<br />
br_nf_pre_routing_finish_bridge_slow<br />
skb->dev = nf_bridge->physindev<br />
br_handle_frame_finish<br />
<br />
Let&#39;s use plain ifindex instead of net_device link. To peek into the<br />
original net_device we will use dev_get_by_index_rcu(). Thus either we<br />
get device and are safe to use it or we don&#39;t get it and drop skb.
Impact
Base Score 3.x
5.50
Severity 3.x
MEDIUM
Vulnerable products and versions
| CPE | From | Up to |
|---|---|---|
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 4.2 (including) | 6.1.75 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.2 (including) | 6.6.14 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.7 (including) | 6.7.2 (excluding) |
To consult the complete list of CPE names with products and versions, see this page
References to Advisories, Solutions, and Tools
- https://git.kernel.org/stable/c/544add1f1cfb78c3dfa3e6edcf4668f6be5e730c
- https://git.kernel.org/stable/c/7ae19ee81ca56b13c50a78de6c47d5b8fdc9d97b
- https://git.kernel.org/stable/c/9325e3188a9cf3f69fc6f32af59844bbc5b90547
- https://git.kernel.org/stable/c/9874808878d9eed407e3977fd11fee49de1e1d86
- https://git.kernel.org/stable/c/544add1f1cfb78c3dfa3e6edcf4668f6be5e730c
- https://git.kernel.org/stable/c/7ae19ee81ca56b13c50a78de6c47d5b8fdc9d97b
- https://git.kernel.org/stable/c/9325e3188a9cf3f69fc6f32af59844bbc5b90547
- https://git.kernel.org/stable/c/9874808878d9eed407e3977fd11fee49de1e1d86



