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.
{
"cna_assigner": "Linux",
"osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2022/49xxx/CVE-2022-49873.json"
}[
{
"digest": {
"length": 310.0,
"function_hash": "86970995712284073911234276435896911262"
},
"signature_version": "v1",
"deprecated": false,
"signature_type": "Function",
"id": "CVE-2022-49873-22cc2dcb",
"target": {
"function": "release_reference",
"file": "kernel/bpf/verifier.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@ae5ccad6c711db0f2ca1231be051935dd128b8f5"
},
{
"digest": {
"threshold": 0.9,
"line_hashes": [
"58602515168108372695441352858311197430",
"329079171812386360491761994686936596223",
"6762055477635818335044629353497163876",
"328077743567977203175428156740805248714",
"137721301392252032070799853269334686346"
]
},
"signature_version": "v1",
"deprecated": false,
"signature_type": "Line",
"id": "CVE-2022-49873-4299e293",
"target": {
"file": "kernel/bpf/verifier.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@f1db20814af532f85e091231223e5e4818e8464b"
},
{
"digest": {
"threshold": 0.9,
"line_hashes": [
"58602515168108372695441352858311197430",
"329079171812386360491761994686936596223",
"6762055477635818335044629353497163876",
"328077743567977203175428156740805248714",
"137721301392252032070799853269334686346"
]
},
"signature_version": "v1",
"deprecated": false,
"signature_type": "Line",
"id": "CVE-2022-49873-61213c6e",
"target": {
"file": "kernel/bpf/verifier.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@cedd4f01f67be94735f15123158f485028571037"
},
{
"digest": {
"threshold": 0.9,
"line_hashes": [
"58602515168108372695441352858311197430",
"329079171812386360491761994686936596223",
"6762055477635818335044629353497163876",
"328077743567977203175428156740805248714",
"137721301392252032070799853269334686346"
]
},
"signature_version": "v1",
"deprecated": false,
"signature_type": "Line",
"id": "CVE-2022-49873-868e9f4d",
"target": {
"file": "kernel/bpf/verifier.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@466ce46f251dfb259a8cbaa895ab9edd6fb56240"
},
{
"digest": {
"length": 310.0,
"function_hash": "86970995712284073911234276435896911262"
},
"signature_version": "v1",
"deprecated": false,
"signature_type": "Function",
"id": "CVE-2022-49873-8eacb055",
"target": {
"function": "release_reference",
"file": "kernel/bpf/verifier.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@cedd4f01f67be94735f15123158f485028571037"
},
{
"digest": {
"length": 310.0,
"function_hash": "86970995712284073911234276435896911262"
},
"signature_version": "v1",
"deprecated": false,
"signature_type": "Function",
"id": "CVE-2022-49873-99e5af3e",
"target": {
"function": "release_reference",
"file": "kernel/bpf/verifier.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@466ce46f251dfb259a8cbaa895ab9edd6fb56240"
},
{
"digest": {
"length": 310.0,
"function_hash": "86970995712284073911234276435896911262"
},
"signature_version": "v1",
"deprecated": false,
"signature_type": "Function",
"id": "CVE-2022-49873-ca33553f",
"target": {
"function": "release_reference",
"file": "kernel/bpf/verifier.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@f1db20814af532f85e091231223e5e4818e8464b"
},
{
"digest": {
"threshold": 0.9,
"line_hashes": [
"58602515168108372695441352858311197430",
"329079171812386360491761994686936596223",
"6762055477635818335044629353497163876",
"328077743567977203175428156740805248714",
"137721301392252032070799853269334686346"
]
},
"signature_version": "v1",
"deprecated": false,
"signature_type": "Line",
"id": "CVE-2022-49873-cdebc8e4",
"target": {
"file": "kernel/bpf/verifier.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@ae5ccad6c711db0f2ca1231be051935dd128b8f5"
}
]
"https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2022-49873.json"