Lucene search

K
cveLinuxCVE-2021-47365
HistoryMay 21, 2024 - 3:15 p.m.

CVE-2021-47365

2024-05-2115:15:22
Linux
web.nvd.nist.gov
41
linux kernel
vulnerability
cve-2021-47365
fix page leak
afs_extend_writeback()
efficiency
ram
nvd
kernel vulnerability

AI Score

6.8

Confidence

Low

EPSS

0

Percentile

9.0%

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

afs: Fix page leak

There’s a loop in afs_extend_writeback() that adds extra pages to a write
we want to make to improve the efficiency of the writeback by making it
larger. This loop stops, however, if we hit a page we can’t write back
from immediately, but it doesn’t get rid of the page ref we speculatively
acquired.

This was caused by the removal of the cleanup loop when the code switched
from using find_get_pages_contig() to xarray scanning as the latter only
gets a single page at a time, not a batch.

Fix this by putting the page on a ref on an early break from the loop.
Unfortunately, we can’t just add that page to the pagevec we’re employing
as we’ll go through that and add those pages to the RPC call.

This was found by the generic/074 test. It leaks ~4GiB of RAM each time it
is run - which can be observed with “top”.

Affected configurations

Vulners
Node
linuxlinux_kernelRange5.135.14.9
OR
linuxlinux_kernelRange5.15.0
VendorProductVersionCPE
linuxlinux_kernel*cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*

CNA Affected

[
  {
    "product": "Linux",
    "vendor": "Linux",
    "defaultStatus": "unaffected",
    "repo": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git",
    "programFiles": [
      "fs/afs/write.c"
    ],
    "versions": [
      {
        "version": "e87b03f5830e",
        "lessThan": "d130b5fdd422",
        "status": "affected",
        "versionType": "git"
      },
      {
        "version": "e87b03f5830e",
        "lessThan": "581b2027af00",
        "status": "affected",
        "versionType": "git"
      }
    ]
  },
  {
    "product": "Linux",
    "vendor": "Linux",
    "defaultStatus": "affected",
    "repo": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git",
    "programFiles": [
      "fs/afs/write.c"
    ],
    "versions": [
      {
        "version": "5.13",
        "status": "affected"
      },
      {
        "version": "0",
        "lessThan": "5.13",
        "status": "unaffected",
        "versionType": "custom"
      },
      {
        "version": "5.14.9",
        "lessThanOrEqual": "5.14.*",
        "status": "unaffected",
        "versionType": "custom"
      },
      {
        "version": "5.15",
        "lessThanOrEqual": "*",
        "status": "unaffected",
        "versionType": "original_commit_for_fix"
      }
    ]
  }
]

AI Score

6.8

Confidence

Low

EPSS

0

Percentile

9.0%