CVE-2022-49873

Source
https://cve.org/CVERecord?id=CVE-2022-49873
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2022-49873.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2022-49873
Downstream
Published
2025-05-01T14:10:23.128Z
Modified
2026-03-20T12:24:45.660999Z
Severity
  • 5.5 (Medium) CVSS_V3 - CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H CVSS Calculator
Summary
bpf: Fix wrong reg type conversion in release_reference()
Details

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

bpf: Fix wrong reg type conversion in release_reference()

Some helper functions will allocate memory. To avoid memory leaks, the verifier requires the eBPF program to release these memories by calling the corresponding helper functions.

When a resource is released, all pointer registers corresponding to the resource should be invalidated. The verifier use release_references() to do this job, by apply __markregunknown() to each relevant register.

It will give these registers the type of SCALARVALUE. A register that will contain a pointer value at runtime, but of type SCALARVALUE, which may allow the unprivileged user to get a kernel pointer by storing this register into a map.

Using _markregnotinit() while NOT allowptrleaks can mitigate this problem.

Database specific
{
    "cna_assigner": "Linux",
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2022/49xxx/CVE-2022-49873.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
fd978bf7fd312581a7ca454a991f0ffb34c4204b
Fixed
cedd4f01f67be94735f15123158f485028571037
Fixed
466ce46f251dfb259a8cbaa895ab9edd6fb56240
Fixed
ae5ccad6c711db0f2ca1231be051935dd128b8f5
Fixed
f1db20814af532f85e091231223e5e4818e8464b

Database specific

source
"https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2022-49873.json"