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-22980
PUBLISHED
More InfoOfficial Page
Assigner-Linux
Assigner Org ID-416baaa9-dc9f-4396-8d5f-8c081fb06d67
View Known Exploited Vulnerability (KEV) details
Published At-23 Jan, 2026 | 15:24
Updated At-09 Feb, 2026 | 08:36
Rejected At-
▼CVE Numbering Authority (CNA)
nfsd: provide locking for v4_end_grace

In the Linux kernel, the following vulnerability has been resolved: nfsd: provide locking for v4_end_grace Writing to v4_end_grace can race with server shutdown and result in memory being accessed after it was freed - reclaim_str_hashtbl in particularly. We cannot hold nfsd_mutex across the nfsd4_end_grace() call as that is held while client_tracking_op->init() is called and that can wait for an upcall to nfsdcltrack which can write to v4_end_grace, resulting in a deadlock. nfsd4_end_grace() is also called by the landromat work queue and this doesn't require locking as server shutdown will stop the work and wait for it before freeing anything that nfsd4_end_grace() might access. However, we must be sure that writing to v4_end_grace doesn't restart the work item after shutdown has already waited for it. For this we add a new flag protected with nn->client_lock. It is set only while it is safe to make client tracking calls, and v4_end_grace only schedules work while the flag is set with the spinlock held. So this patch adds a nfsd_net field "client_tracking_active" which is set as described. Another field "grace_end_forced", is set when v4_end_grace is written. After this is set, and providing client_tracking_active is set, the laundromat is scheduled. This "grace_end_forced" field bypasses other checks for whether the grace period has finished. This resolves a race which can result in use-after-free.

Affected Products
Vendor
Linux Kernel Organization, IncLinux
Product
Linux
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Program Files
  • fs/nfsd/netns.h
  • fs/nfsd/nfs4state.c
  • fs/nfsd/nfsctl.c
  • fs/nfsd/state.h
Default Status
unaffected
Versions
Affected
  • From 7f5ef2e900d9462bf9cffaf6bb246ed87a20a6d6 before ca97360860eb02e3ae4ba42c19b439a0fcecbf06 (git)
  • From 7f5ef2e900d9462bf9cffaf6bb246ed87a20a6d6 before e8bfa2401d4c51eca6e48e9b33c798828ca9df61 (git)
  • From 7f5ef2e900d9462bf9cffaf6bb246ed87a20a6d6 before 34eb22836e0cdba093baac66599d68c4cd245a9d (git)
  • From 7f5ef2e900d9462bf9cffaf6bb246ed87a20a6d6 before 06600719d0f7a723811c45e4d51f5b742f345309 (git)
  • From 7f5ef2e900d9462bf9cffaf6bb246ed87a20a6d6 before ba4811c8b433bfa681729ca42cc62b6034f223b0 (git)
  • From 7f5ef2e900d9462bf9cffaf6bb246ed87a20a6d6 before 53f07d095e7e680c5e4569a55a019f2c0348cdc6 (git)
  • From 7f5ef2e900d9462bf9cffaf6bb246ed87a20a6d6 before 2857bd59feb63fcf40fe4baf55401baea6b4feb4 (git)
Vendor
Linux Kernel Organization, IncLinux
Product
Linux
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Program Files
  • fs/nfsd/netns.h
  • fs/nfsd/nfs4state.c
  • fs/nfsd/nfsctl.c
  • fs/nfsd/state.h
Default Status
affected
Versions
Affected
  • 3.18
Unaffected
  • From 0 before 3.18 (semver)
  • From 5.10.248 through 5.10.* (semver)
  • From 5.15.198 through 5.15.* (semver)
  • From 6.1.161 through 6.1.* (semver)
  • From 6.6.121 through 6.6.* (semver)
  • From 6.12.66 through 6.12.* (semver)
  • From 6.18.6 through 6.18.* (semver)
  • From 6.19 through * (original_commit_for_fix)
Metrics
VersionBase scoreBase severityVector
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/ca97360860eb02e3ae4ba42c19b439a0fcecbf06
N/A
https://git.kernel.org/stable/c/e8bfa2401d4c51eca6e48e9b33c798828ca9df61
N/A
https://git.kernel.org/stable/c/34eb22836e0cdba093baac66599d68c4cd245a9d
N/A
https://git.kernel.org/stable/c/06600719d0f7a723811c45e4d51f5b742f345309
N/A
https://git.kernel.org/stable/c/ba4811c8b433bfa681729ca42cc62b6034f223b0
N/A
https://git.kernel.org/stable/c/53f07d095e7e680c5e4569a55a019f2c0348cdc6
N/A
https://git.kernel.org/stable/c/2857bd59feb63fcf40fe4baf55401baea6b4feb4
N/A
Hyperlink: https://git.kernel.org/stable/c/ca97360860eb02e3ae4ba42c19b439a0fcecbf06
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/e8bfa2401d4c51eca6e48e9b33c798828ca9df61
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/34eb22836e0cdba093baac66599d68c4cd245a9d
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/06600719d0f7a723811c45e4d51f5b742f345309
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/ba4811c8b433bfa681729ca42cc62b6034f223b0
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/53f07d095e7e680c5e4569a55a019f2c0348cdc6
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/2857bd59feb63fcf40fe4baf55401baea6b4feb4
Resource: N/A
Details not found