CVE-2026-23286

Source
https://cve.org/CVERecord?id=CVE-2026-23286
Import Source
https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2026-23286.json
JSON Data
https://api.osv.dev/v1/vulns/CVE-2026-23286
Downstream
Published
2026-03-25T10:26:45.531Z
Modified
2026-04-02T13:12:19.723021Z
Summary
atm: lec: fix null-ptr-deref in lec_arp_clear_vccs
Details

In the Linux kernel, the following vulnerability has been resolved:

atm: lec: fix null-ptr-deref in lecarpclear_vccs

syzkaller reported a null-ptr-deref in lecarpclear_vccs(). This issue can be easily reproduced using the syzkaller reproducer.

In the ATM LANE (LAN Emulation) module, the same atmvcc can be shared by multiple lecarptable entries (e.g., via entry->vcc or entry->recvvcc). When the underlying VCC is closed, lecvccclose() iterates over all ARP entries and calls lecarpclear_vccs() for each matched entry.

For example, when lecvccclose() iterates through the hlists in priv->lecarpempty_ones or other ARP tables:

  1. In the first iteration, for the first matched ARP entry sharing the VCC, lecarpclearvccs() frees the associated vpriv (which is vcc->userback) and sets vcc->user_back to NULL.
  2. In the second iteration, for the next matched ARP entry sharing the same VCC, lecarpclearvccs() is called again. It obtains a NULL vpriv from vcc->userback (via LECVCCPRIV(vcc)) and then attempts to dereference it via vcc->pop = vpriv->old_pop, leading to a null-ptr-deref crash.

Fix this by adding a null check for vpriv before dereferencing it. If vpriv is already NULL, it means the VCC has been cleared by a previous call, so we can safely skip the cleanup and just clear the entry's vcc/recv_vcc pointers.

The entire cleanup block (including vccreleaseasync()) is placed inside the vpriv guard because a NULL vpriv indicates the VCC has already been fully released by a prior iteration — repeating the teardown would redundantly set flags and trigger callbacks on an already-closing socket.

The Fixes tag points to the initial commit because the entry->vcc path has been vulnerable since the original code. The entry->recvvcc path was later added by commit 8d9f73c0ad2f ("atm: fix a memory leak of vcc->userback") with the same pattern, and both paths are fixed here.

Database specific
{
    "cna_assigner": "Linux",
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2026/23xxx/CVE-2026-23286.json"
}
References

Affected packages

Git / git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git

Affected ranges

Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
1da177e4c3f41524e886b7f1b8a0c1fc7321cac2
Fixed
e9665986eb127290ceb535bd5d04d7a84265d94f
Fixed
622062f24644b4536d3f437e0cf7a8c4bb421665
Fixed
2d9f57ea29a1f1772373b98a509b44d49fda609e
Fixed
7ea92ab075d809ec8a96669a5ecf00f752057875
Fixed
5f1cfea7921f5c126a441d973690eeba52677b64
Fixed
101bacb303e89dc2e0640ae6a5e0fb97c4eb45bb

Database specific

source
"https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2026-23286.json"

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
2.6.12
Fixed
6.1.167
Type
ECOSYSTEM
Events
Introduced
6.2.0
Fixed
6.6.130
Type
ECOSYSTEM
Events
Introduced
6.7.0
Fixed
6.12.77
Type
ECOSYSTEM
Events
Introduced
6.13.0
Fixed
6.18.17
Type
ECOSYSTEM
Events
Introduced
6.19.0
Fixed
6.19.7

Database specific

source
"https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2026-23286.json"