CVE-2026-23396
Severity CVSS v4.0:
Pending analysis
Type:
CWE-476
NULL Pointer Dereference
Publication date:
26/03/2026
Last modified:
24/04/2026
Description
In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
wifi: mac80211: fix NULL deref in mesh_matches_local()<br />
<br />
mesh_matches_local() unconditionally dereferences ie->mesh_config to<br />
compare mesh configuration parameters. When called from<br />
mesh_rx_csa_frame(), the parsed action-frame elements may not contain a<br />
Mesh Configuration IE, leaving ie->mesh_config NULL and triggering a<br />
kernel NULL pointer dereference.<br />
<br />
The other two callers are already safe:<br />
- ieee80211_mesh_rx_bcn_presp() checks !elems->mesh_config before<br />
calling mesh_matches_local()<br />
- mesh_plink_get_event() is only reached through<br />
mesh_process_plink_frame(), which checks !elems->mesh_config, too<br />
<br />
mesh_rx_csa_frame() is the only caller that passes raw parsed elements<br />
to mesh_matches_local() without guarding mesh_config. An adjacent<br />
attacker can exploit this by sending a crafted CSA action frame that<br />
includes a valid Mesh ID IE but omits the Mesh Configuration IE,<br />
crashing the kernel.<br />
<br />
The captured crash log:<br />
<br />
Oops: general protection fault, probably for non-canonical address ...<br />
KASAN: null-ptr-deref in range [0x0000000000000000-0x0000000000000007]<br />
Workqueue: events_unbound cfg80211_wiphy_work<br />
[...]<br />
Call Trace:<br />
<br />
? __pfx_mesh_matches_local (net/mac80211/mesh.c:65)<br />
ieee80211_mesh_rx_queued_mgmt (net/mac80211/mesh.c:1686)<br />
[...]<br />
ieee80211_iface_work (net/mac80211/iface.c:1754 net/mac80211/iface.c:1802)<br />
[...]<br />
cfg80211_wiphy_work (net/wireless/core.c:426)<br />
process_one_work (net/kernel/workqueue.c:3280)<br />
? assign_work (net/kernel/workqueue.c:1219)<br />
worker_thread (net/kernel/workqueue.c:3352)<br />
? __pfx_worker_thread (net/kernel/workqueue.c:3385)<br />
kthread (net/kernel/kthread.c:436)<br />
[...]<br />
ret_from_fork_asm (net/arch/x86/entry/entry_64.S:255)<br />
<br />
<br />
This patch adds a NULL check for ie->mesh_config at the top of<br />
mesh_matches_local() to return false early when the Mesh Configuration<br />
IE is absent.
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:*:*:*:*:*:*:*:* | 2.6.26.1 (including) | 5.10.253 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.11 (including) | 5.15.203 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.16 (including) | 6.1.167 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.2 (including) | 6.6.130 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.7 (including) | 6.12.78 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.13 (including) | 6.18.20 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.19 (including) | 6.19.10 (excluding) |
| cpe:2.3:o:linux:linux_kernel:2.6.26:-:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:7.0:rc1:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:7.0:rc2:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:7.0:rc3:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:7.0:rc4:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:7.0:rc5:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:7.0:rc6:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:7.0:rc7:*:*:*:*:*:* |
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/0a4da176ae4b4e075a19c00d3e269cfd5e05a813
- https://git.kernel.org/stable/c/14a4fd13657a3f2489db6566f081adfb27a49c64
- https://git.kernel.org/stable/c/44699c6cdfce80a0f296b54ae9314461e3e41b3d
- https://git.kernel.org/stable/c/74de6fa472b03bc8cde0a081484e9960bcbda568
- https://git.kernel.org/stable/c/7c55a3deaf7eaaafa2546f8de7fed19382a0a116
- https://git.kernel.org/stable/c/a90279e7f7ea0b7e923a1c5ebee9a6b78b6d1004
- https://git.kernel.org/stable/c/c1e3f2416fb27c816ce96d747d3e784e31f4d95c
- https://git.kernel.org/stable/c/c73bb9a2d33bf81f6eecaa0f474b6c6dbe9855bd



