Logo
-

Byte Open Security

(ByteOS Network)

Log In

Sign Up

ByteOS

Security
Vulnerability Details
Registries
Custom Views
Weaknesses
Attack Patterns
Filters & Tools
CVE Vulnerability Details :
CVE-2026-53264
PUBLISHED
More InfoOfficial Page
Assigner-Linux
Assigner Org ID-416baaa9-dc9f-4396-8d5f-8c081fb06d67
View Known Exploited Vulnerability (KEV) details
Published At-25 Jun, 2026 | 08:39
Updated At-28 Jun, 2026 | 06:41
Rejected At-
▼CVE Numbering Authority (CNA)
net/sched: act_api: use RCU with deferred freeing for action lifecycle

In the Linux kernel, the following vulnerability has been resolved: net/sched: act_api: use RCU with deferred freeing for action lifecycle When NEWTFILTER and DELFILTER are run concurrently it is possible to create a race with an associated action. Let's illustrate with CPU0 running NEWTFILTER and CPU1 running DELFILTER: 0: mutex_lock() <-- holds the idr lock 0: rcu_read_lock() 0: p = idr_find(idr, index) <-- action p is valid (RCU protects IDR) 0: mutex_unlock() <-- releases the idr lock 1: refcount_dec_and_mutex_lock() <-- refcnt 1->0, mutex held 1: idr_remove(idr, index) <-- Action removed from IDR 1: mutex_unlock() <-- mutex released allowing us to delete the action 1: tcf_action_cleanup(p); kfree(p) <-- Kfrees p immediately, no deferral 0: refcount_inc_not_zero(&p->tcfa_refcnt) <-- ouch, UAF p points to freed memory This patch fixes the race condition between NEWTFILTER and DELFILTER by adding struct rcu_head to tc_action used in the deferral and introducing a call_rcu() in the delete path to defer the final kfree(). Note: this is a revert of commit d7fb60b9cafb ("net_sched: get rid of tcfa_rcu") but also modernization/simplification to directly use kfree_rcu(). Let's illustrate the new restored code path: 0: rcu_read_lock() 1: refcount_dec_and_mutex_lock() <-- refcnt 1->0, mutex held 1: idr_remove(idr, index) 1: mutex_unlock() 1: call_rcu(&p->tcfa_rcu, tcf_action_rcu_free) <-- defer kfree after grace period 0: p = idr_find(idr, index) 0: refcount_inc_not_zero(&p->tcfa_refcnt) <-- fails, refcnt already 0 1: rcu_read_unlock() <-- release so freeing can run after grace period After CPU1 calls idr_remove(), the object is no longer reachable through the IDR. CPU0's subsequent idr_find() will return NULL, and even if it still held a stale pointer, the immediate kfree() is now deferred until after the RCU grace period, so no UAF can occur.

Affected Products
Vendor
Linux Kernel Organization, IncLinux
Product
Linux
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Program Files
  • include/net/act_api.h
  • net/sched/act_api.c
Default Status
unaffected
Versions
Affected
  • From d7fb60b9cafb982cb2e46a267646a8dfd4f2e5da before 98b2e40879abf0245be5a5b7af69e0f6ff524ac3 (git)
  • From d7fb60b9cafb982cb2e46a267646a8dfd4f2e5da before 18af5d2ef0c4f65787fd1280c8b23286b9f2a835 (git)
  • From d7fb60b9cafb982cb2e46a267646a8dfd4f2e5da before 1f1b98fea6b9ea30507d0f2fbff6750292d097e2 (git)
  • From d7fb60b9cafb982cb2e46a267646a8dfd4f2e5da before 8b136f18ac4b2ace5aaad3305b3f8a5d8165a009 (git)
  • From d7fb60b9cafb982cb2e46a267646a8dfd4f2e5da before 5dd51e09020c65aa53cf128e5e3517cd53b3c113 (git)
  • From d7fb60b9cafb982cb2e46a267646a8dfd4f2e5da before b60e9391142e983fab2be53497aa8f71fdd09cd5 (git)
  • From d7fb60b9cafb982cb2e46a267646a8dfd4f2e5da before 91d105d2cbe002f9c7b43a6183adedc37e1da1f7 (git)
  • From d7fb60b9cafb982cb2e46a267646a8dfd4f2e5da before 5057e1aca011e51ef51498c940ef96f3d3e8a305 (git)
Vendor
Linux Kernel Organization, IncLinux
Product
Linux
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Program Files
  • include/net/act_api.h
  • net/sched/act_api.c
Default Status
affected
Versions
Affected
  • 4.14
Unaffected
  • From 0 before 4.14 (semver)
  • From 5.10.259 through 5.10.* (semver)
  • From 5.15.210 through 5.15.* (semver)
  • From 6.1.176 through 6.1.* (semver)
  • From 6.6.143 through 6.6.* (semver)
  • From 6.12.94 through 6.12.* (semver)
  • From 6.18.36 through 6.18.* (semver)
  • From 7.0.13 through 7.0.* (semver)
  • From 7.1 through * (original_commit_for_fix)
Metrics
VersionBase scoreBase severityVector
3.17.8HIGH
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H
Version: 3.1
Base score: 7.8
Base severity: HIGH
Vector:
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H
Metrics Other Info
Impacts
CAPEC IDDescription
Solutions

Configurations

Workarounds

Exploits

Credits

Timeline
EventDate
Replaced By

Rejected Reason

References
HyperlinkResource
https://git.kernel.org/stable/c/98b2e40879abf0245be5a5b7af69e0f6ff524ac3
N/A
https://git.kernel.org/stable/c/18af5d2ef0c4f65787fd1280c8b23286b9f2a835
N/A
https://git.kernel.org/stable/c/1f1b98fea6b9ea30507d0f2fbff6750292d097e2
N/A
https://git.kernel.org/stable/c/8b136f18ac4b2ace5aaad3305b3f8a5d8165a009
N/A
https://git.kernel.org/stable/c/5dd51e09020c65aa53cf128e5e3517cd53b3c113
N/A
https://git.kernel.org/stable/c/b60e9391142e983fab2be53497aa8f71fdd09cd5
N/A
https://git.kernel.org/stable/c/91d105d2cbe002f9c7b43a6183adedc37e1da1f7
N/A
https://git.kernel.org/stable/c/5057e1aca011e51ef51498c940ef96f3d3e8a305
N/A
Hyperlink: https://git.kernel.org/stable/c/98b2e40879abf0245be5a5b7af69e0f6ff524ac3
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/18af5d2ef0c4f65787fd1280c8b23286b9f2a835
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/1f1b98fea6b9ea30507d0f2fbff6750292d097e2
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/8b136f18ac4b2ace5aaad3305b3f8a5d8165a009
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/5dd51e09020c65aa53cf128e5e3517cd53b3c113
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/b60e9391142e983fab2be53497aa8f71fdd09cd5
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/91d105d2cbe002f9c7b43a6183adedc37e1da1f7
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/5057e1aca011e51ef51498c940ef96f3d3e8a305
Resource: N/A
Details not found