CVE-2023-52447
MediumIn the Linux kernel, the following vulnerability has been resolved: bpf: Defer the free of inner map when necessary When updating or deleting an inner map in map array or map htab, the map may still be accessed by non-sleepable program or sleepable program. However bpf_map_fd_put_ptr() decreases the ref-counter of the inner map directly through bpf_map_put(), if the ref-counter is the last one (which is true for most cases), the inner map will be freed by ops->map_free() in a kworker. But for now, most .map_free() callbacks don't use synchronize_rcu() or its variants to wait for the elapse of a RCU grace period, so after the invocation of ops->map_free completes, the bpf program which is accessing the inner map may incur use-after-free problem. Fix the free of inner map by invoking bpf_map_free_deferred() after both one RCU grace period and one tasks trace RCU grace period if the inner map has been removed from the outer map before. The deferment is accomplished by using call_rcu() or call_rcu_tasks_trace() when releasing the last ref-counter of bpf map. The newly-added rcu_head field in bpf_map shares the same storage space with work field to reduce the size of bpf_map.
CVSS 3.1 score
6.7
CVSS:3.1/AV:L/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:H
Weakness type
CWE-416CVE-2023-52447 is a Use After Free vulnerability
What is Use After Free?
The product references memory after it has been freed, which may cause it to crash, use unexpected values, or execute code. Learn more on MITRE CWE
References
The following references provide additional information about CVE-2023-52447 including vendor advisories, patch commits, exploit details, and third-party analysis. Links are sourced from the NIST NVD database.
-
-
-
PatchKernel patch commithttps://git.kernel.org/stable/c/37d98fb9c3144c0fddf7f6e99aece9927ac8dce6
-
PatchKernel patch commithttps://git.kernel.org/stable/c/62fca83303d608ad4fec3f7428c8685680bb01b0
-
PatchKernel patch commithttps://git.kernel.org/stable/c/876673364161da50eed6b472d746ef88242b2368
Frequently asked questions
-
What is CVE-2023-52447?
CVE-2023-52447 is a Medium severity Linux kernel vulnerability with a CVSS score of 6.7 out of 10 , classified as an Use After Free flaw (CWE-416) . CVE-2023-52447 has not been confirmed as actively exploited and is not listed in the CISA KEV catalog.
-
What is the CVSS score for CVE-2023-52447?
CVE-2023-52447 has a CVSS score of 6.7 out of 10, rated Medium severity (CVSS 3.1). The vector string is
CVSS:3.1/AV:L/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:H. -
Is there a patch available for CVE-2023-52447?
No patch is currently available for CVE-2023-52447. Monitor the NIST NVD and your Linux distribution's security advisories for updates.
-
Is CVE-2023-52447 actively exploited?
No — CVE-2023-52447 has not been confirmed as actively exploited. It is not listed in the CISA Known Exploited Vulnerabilities (KEV) catalog.
-
What is Use After Free (CWE-416)?
The product references memory after it has been freed, which may cause it to crash, use unexpected values, or execute code. View CWE-416 on MITRE CWE →