Upstream information
Description
In the Linux kernel, the following vulnerability has been resolved:bpf: Fix UAF due to race between btf_try_get_module and load_module
While working on code to populate kfunc BTF ID sets for module BTF from
its initcall, I noticed that by the time the initcall is invoked, the
module BTF can already be seen by userspace (and the BPF verifier). The
existing btf_try_get_module calls try_module_get which only fails if
mod->state == MODULE_STATE_GOING, i.e. it can increment module reference
when module initcall is happening in parallel.
Currently, BTF parsing happens from MODULE_STATE_COMING notifier
callback. At this point, the module initcalls have not been invoked.
The notifier callback parses and prepares the module BTF, allocates an
ID, which publishes it to userspace, and then adds it to the btf_modules
list allowing the kernel to invoke btf_try_get_module for the BTF.
However, at this point, the module has not been fully initialized (i.e.
its initcalls have not finished). The code in module.c can still fail
and free the module, without caring for other users. However, nothing
stops btf_try_get_module from succeeding between the state transition
from MODULE_STATE_COMING to MODULE_STATE_LIVE.
This leads to a use-after-free issue when BPF program loads
successfully in the state transition, load_module's do_init_module call
fails and frees the module, and BPF program fd on close calls module_put
for the freed module. Future patch has test case to verify we don't
regress in this area in future.
There are multiple points after prepare_coming_module (in load_module)
where failure can occur and module loading can return error. We
illustrate and test for the race using the last point where it can
practically occur (in module __init function).
An illustration of the race:
CPU 0 CPU 1
load_module
notifier_call(MODULE_STATE_COMING)
btf_parse_module
btf_alloc_id // Published to userspace
list_add(&btf_mod->list, btf_modules)
mod->init(...)
... ^
bpf_check |
check_pseudo_btf_id |
btf_try_get_module |
returns true | ...
... | module __init in progress
return prog_fd | ...
... V
if (ret < 0)
free_module(mod)
...
close(prog_fd)
...
bpf_prog_free_deferred
module_put(used_btf.mod) // use-after-free
We fix this issue by setting a flag BTF_MODULE_F_LIVE, from the notifier
callback when MODULE_STATE_LIVE state is reached for the module, so that
we return NULL from btf_try_get_module for modules that are not fully
formed. Since try_module_get already checks that module is not in
MODULE_STATE_GOING state, and that is the only transition a live module
can make before being removed from btf_modules list, this is enough to
close the race and prevent the bug.
A later selftest patch crafts the race condition artifically to verify
that it has been fixed, and that verifier fails to load program (with
ENXIO).
Lastly, a couple of comments:
1. Even if this race didn't exist, it seems more appropriate to only
access resources (ksyms and kfuncs) of a fully formed module which
has been initialized completely.
2. This patch was born out of need for synchronization against module
initcall for the next patch, so it is needed for correctness even
without the aforementioned race condition. The BTF resources
initialized by module initcall are set up once and then only looked
up, so just waiting until the initcall has finished ensures correct
behavior.
SUSE information
Overall state of this security issue: New
This issue is currently rated as having not set severity.
No SUSE Bugzilla entries cross referenced. No SUSE Security Announcements cross referenced.Status of this issue by product and package
Please note that this evaluation state might be work in progress, incomplete or outdated. Also information for service packs in the LTSS phase is only included for issues meeting the LTSS criteria. If in doubt, feel free to contact us for clarification. The updates are grouped by state of their lifecycle. SUSE product lifecycles are documented on the lifecycle page.
Product(s) | Source package | State |
---|---|---|
Products under general support and receiving all security fixes. | ||
SUSE Linux Enterprise Desktop 15 SP6 | kernel-default | Analysis |
SUSE Linux Enterprise Desktop 15 SP6 | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP6 | kernel-default | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP6 | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP6 | kernel-source-azure | Analysis |
SUSE Linux Enterprise Live Patching 15 SP6 | kernel-default | Analysis |
SUSE Linux Enterprise Live Patching 15 SP6 | kernel-source | Analysis |
SUSE Linux Enterprise Micro 5.1 | kernel-default | Analysis |
SUSE Linux Enterprise Micro 5.1 | kernel-rt | Analysis |
SUSE Linux Enterprise Micro 5.1 | kernel-source | Analysis |
SUSE Linux Enterprise Micro 5.1 | kernel-source-rt | Analysis |
SUSE Linux Enterprise Micro 5.2 | kernel-default | Analysis |
SUSE Linux Enterprise Micro 5.2 | kernel-rt | Analysis |
SUSE Linux Enterprise Micro 5.2 | kernel-source | Analysis |
SUSE Linux Enterprise Micro 5.2 | kernel-source-rt | Analysis |
SUSE Linux Enterprise Micro 5.3 | kernel-default | Analysis |
SUSE Linux Enterprise Micro 5.3 | kernel-rt | Analysis |
SUSE Linux Enterprise Micro 5.3 | kernel-source | Analysis |
SUSE Linux Enterprise Micro 5.3 | kernel-source-rt | Analysis |
SUSE Linux Enterprise Micro 5.4 | kernel-default | Analysis |
SUSE Linux Enterprise Micro 5.4 | kernel-rt | Analysis |
SUSE Linux Enterprise Micro 5.4 | kernel-source | Analysis |
SUSE Linux Enterprise Micro 5.4 | kernel-source-rt | Analysis |
SUSE Linux Enterprise Micro 5.5 | kernel-default | Analysis |
SUSE Linux Enterprise Micro 5.5 | kernel-source | Analysis |
SUSE Linux Enterprise Micro 5.5 | kernel-source-rt | Analysis |
SUSE Linux Enterprise Module for Basesystem 15 SP6 | kernel-default | Analysis |
SUSE Linux Enterprise Module for Basesystem 15 SP6 | kernel-source | Analysis |
SUSE Linux Enterprise Module for Development Tools 15 SP6 | kernel-default | Analysis |
SUSE Linux Enterprise Module for Development Tools 15 SP6 | kernel-source | Analysis |
SUSE Linux Enterprise Module for Public Cloud 15 SP6 | kernel-source-azure | Analysis |
SUSE Linux Enterprise Real Time 15 SP6 | kernel-source-rt | Analysis |
SUSE Linux Enterprise Server 15 SP6 | kernel-default | Analysis |
SUSE Linux Enterprise Server 15 SP6 | kernel-source | Analysis |
SUSE Linux Enterprise Server 15 SP6 | kernel-source-azure | Analysis |
SUSE Linux Enterprise Server for SAP Applications 15 SP6 | kernel-default | Analysis |
SUSE Linux Enterprise Server for SAP Applications 15 SP6 | kernel-source | Analysis |
SUSE Linux Enterprise Server for SAP Applications 15 SP6 | kernel-source-azure | Analysis |
SUSE Linux Enterprise Workstation Extension 15 SP6 | kernel-default | Analysis |
SUSE Linux Enterprise Workstation Extension 15 SP6 | kernel-source | Analysis |
SUSE Linux Micro 6.0 | kernel-default | Analysis |
SUSE Linux Micro 6.0 | kernel-source | Analysis |
SUSE Linux Micro 6.0 | kernel-source-rt | Analysis |
SUSE Linux Micro 6.1 | kernel-default | Analysis |
SUSE Linux Micro 6.1 | kernel-source | Analysis |
SUSE Linux Micro 6.1 | kernel-source-rt | Analysis |
SUSE Manager Proxy 4.3 | kernel-default | Analysis |
SUSE Manager Proxy 4.3 | kernel-source | Analysis |
SUSE Manager Retail Branch Server 4.3 | kernel-default | Analysis |
SUSE Manager Retail Branch Server 4.3 | kernel-source | Analysis |
SUSE Manager Server 4.3 | kernel-default | Analysis |
SUSE Manager Server 4.3 | kernel-source | Analysis |
SUSE Real Time Module 15 SP6 | kernel-source-rt | Analysis |
openSUSE Leap 15.6 | kernel-default | Analysis |
openSUSE Leap 15.6 | kernel-source | Analysis |
openSUSE Leap 15.6 | kernel-source-azure | Analysis |
openSUSE Leap 15.6 | kernel-source-rt | Analysis |
Products under Long Term Service Pack support and receiving important and critical security fixes. | ||
SUSE Linux Enterprise High Availability Extension 12 SP5 | kernel-default | Analysis |
SUSE Linux Enterprise High Availability Extension 12 SP5 | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP3 | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP3-ESPOS | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP3-LTSS | kernel-default | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP3-LTSS | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP4 | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP4-LTSS | kernel-default | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP4-LTSS | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP5 | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP5 | kernel-source-azure | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP5-ESPOS | kernel-default | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP5-ESPOS | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP5-LTSS | kernel-default | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP5-LTSS | kernel-source | Analysis |
SUSE Linux Enterprise Live Patching 12 SP5 | kernel-default | Analysis |
SUSE Linux Enterprise Live Patching 12 SP5 | kernel-source | Analysis |
SUSE Linux Enterprise Live Patching 15 SP3 | kernel-default | Analysis |
SUSE Linux Enterprise Live Patching 15 SP3 | kernel-source | Analysis |
SUSE Linux Enterprise Live Patching 15 SP4 | kernel-default | Analysis |
SUSE Linux Enterprise Live Patching 15 SP4 | kernel-source | Analysis |
SUSE Linux Enterprise Live Patching 15 SP5 | kernel-default | Analysis |
SUSE Linux Enterprise Live Patching 15 SP5 | kernel-source | Analysis |
SUSE Linux Enterprise Module for Basesystem 15 SP3 | kernel-source | Analysis |
SUSE Linux Enterprise Module for Basesystem 15 SP4 | kernel-source | Analysis |
SUSE Linux Enterprise Module for Basesystem 15 SP5 | kernel-source | Analysis |
SUSE Linux Enterprise Module for Development Tools 15 SP3 | kernel-source | Analysis |
SUSE Linux Enterprise Module for Development Tools 15 SP4 | kernel-source | Analysis |
SUSE Linux Enterprise Module for Development Tools 15 SP5 | kernel-source | Analysis |
SUSE Linux Enterprise Module for Public Cloud 15 SP5 | kernel-source-azure | Analysis |
SUSE Linux Enterprise Server 11 SP4 LTSS EXTREME CORE | kernel-default | Analysis |
SUSE Linux Enterprise Server 11 SP4 LTSS EXTREME CORE | kernel-source | Analysis |
SUSE Linux Enterprise Server 12 SP5 | kernel-source | Analysis |
SUSE Linux Enterprise Server 12 SP5 | kernel-source-azure | Analysis |
SUSE Linux Enterprise Server 12 SP5-LTSS | kernel-default | Analysis |
SUSE Linux Enterprise Server 12 SP5-LTSS | kernel-source | Analysis |
SUSE Linux Enterprise Server 12 SP5-LTSS | kernel-source-azure | Analysis |
SUSE Linux Enterprise Server 15 SP3 | kernel-source | Analysis |
SUSE Linux Enterprise Server 15 SP3-LTSS | kernel-default | Analysis |
SUSE Linux Enterprise Server 15 SP3-LTSS | kernel-source | Analysis |
SUSE Linux Enterprise Server 15 SP4 | kernel-source | Analysis |
SUSE Linux Enterprise Server 15 SP4-LTSS | kernel-default | Analysis |
SUSE Linux Enterprise Server 15 SP4-LTSS | kernel-source | Analysis |
SUSE Linux Enterprise Server 15 SP5 | kernel-source | Analysis |
SUSE Linux Enterprise Server 15 SP5 | kernel-source-azure | Analysis |
SUSE Linux Enterprise Server 15 SP5-LTSS | kernel-default | Analysis |
SUSE Linux Enterprise Server 15 SP5-LTSS | kernel-source | Analysis |
SUSE Linux Enterprise Server LTSS Extended Security 12 SP5 | kernel-source | Analysis |
SUSE Linux Enterprise Server LTSS Extended Security 12 SP5 | kernel-source-azure | Analysis |
SUSE Linux Enterprise Server for SAP Applications 12 SP5 | kernel-default | Analysis |
SUSE Linux Enterprise Server for SAP Applications 12 SP5 | kernel-source | Analysis |
SUSE Linux Enterprise Server for SAP Applications 15 SP3 | kernel-default | Analysis |
SUSE Linux Enterprise Server for SAP Applications 15 SP3 | kernel-source | Analysis |
SUSE Linux Enterprise Server for SAP Applications 15 SP4 | kernel-default | Analysis |
SUSE Linux Enterprise Server for SAP Applications 15 SP4 | kernel-source | Analysis |
SUSE Linux Enterprise Server for SAP Applications 15 SP5 | kernel-default | Analysis |
SUSE Linux Enterprise Server for SAP Applications 15 SP5 | kernel-source | Analysis |
SUSE Linux Enterprise Server for SAP Applications 15 SP5 | kernel-source-azure | Analysis |
Products past their end of life and not receiving proactive updates anymore. | ||
SUSE CaaS Platform 4.0 | kernel-source | Analysis |
SUSE Enterprise Storage 6 | kernel-source | Analysis |
SUSE Enterprise Storage 7 | kernel-source | Analysis |
SUSE Enterprise Storage 7.1 | kernel-source | Analysis |
SUSE Linux Enterprise Desktop 11 SP4 | kernel-source | Analysis |
SUSE Linux Enterprise Desktop 12 SP2 | kernel-source | Analysis |
SUSE Linux Enterprise Desktop 12 SP4 | kernel-source | Analysis |
SUSE Linux Enterprise Desktop 15 | kernel-source | Analysis |
SUSE Linux Enterprise Desktop 15 SP1 | kernel-source | Analysis |
SUSE Linux Enterprise Desktop 15 SP2 | kernel-source | Analysis |
SUSE Linux Enterprise Desktop 15 SP3 | kernel-source | Analysis |
SUSE Linux Enterprise Desktop 15 SP4 | kernel-source | Analysis |
SUSE Linux Enterprise Desktop 15 SP5 | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP1 | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP1-ESPOS | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP1-LTSS | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP2 | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP2-ESPOS | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP2-LTSS | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15 SP4-ESPOS | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15-ESPOS | kernel-source | Analysis |
SUSE Linux Enterprise High Performance Computing 15-LTSS | kernel-source | Analysis |
SUSE Linux Enterprise Micro 5.0 | kernel-default | Analysis |
SUSE Linux Enterprise Module for Basesystem 15 | kernel-source | Analysis |
SUSE Linux Enterprise Module for Basesystem 15 SP1 | kernel-source | Analysis |
SUSE Linux Enterprise Module for Basesystem 15 SP2 | kernel-source | Analysis |
SUSE Linux Enterprise Module for Development Tools 15 | kernel-source | Analysis |
SUSE Linux Enterprise Module for Development Tools 15 SP1 | kernel-source | Analysis |
SUSE Linux Enterprise Module for Development Tools 15 SP2 | kernel-source | Analysis |
SUSE Linux Enterprise Point of Sale 12 SP2-CLIENT | kernel-source | Analysis |
SUSE Linux Enterprise Real Time 15 SP2 | kernel-source | Analysis |
SUSE Linux Enterprise Real Time 15 SP3 | kernel-source | Analysis |
SUSE Linux Enterprise Real Time 15 SP3 | kernel-source-rt | Analysis |
SUSE Linux Enterprise Real Time 15 SP4 | kernel-source | Analysis |
SUSE Linux Enterprise Real Time 15 SP4 | kernel-source-rt | Analysis |
SUSE Linux Enterprise Real Time 15 SP5 | kernel-source-rt | Analysis |
SUSE Linux Enterprise Server 11 SP4 | kernel-source | Analysis |
SUSE Linux Enterprise Server 11 SP4 LTSS | kernel-default | Analysis |
SUSE Linux Enterprise Server 11 SP4 LTSS | kernel-source | Analysis |
SUSE Linux Enterprise Server 11 SP4-LTSS | kernel-source | Analysis |
SUSE Linux Enterprise Server 12 SP2 | kernel-source | Analysis |
SUSE Linux Enterprise Server 12 SP2-BCL | kernel-source | Analysis |
SUSE Linux Enterprise Server 12 SP2-ESPOS | kernel-source | Analysis |
SUSE Linux Enterprise Server 12 SP2-LTSS | kernel-default | Analysis |
SUSE Linux Enterprise Server 12 SP2-LTSS | kernel-source | Analysis |
SUSE Linux Enterprise Server 12 SP4 | kernel-source | Analysis |
SUSE Linux Enterprise Server 12 SP4-ESPOS | kernel-source | Analysis |
SUSE Linux Enterprise Server 12 SP4-LTSS | kernel-default | Analysis |
SUSE Linux Enterprise Server 12 SP4-LTSS | kernel-source | Analysis |
SUSE Linux Enterprise Server 15 | kernel-source | Analysis |
SUSE Linux Enterprise Server 15 SP1 | kernel-source | Analysis |
SUSE Linux Enterprise Server 15 SP1-BCL | kernel-source | Analysis |
SUSE Linux Enterprise Server 15 SP1-LTSS | kernel-default | Analysis |
SUSE Linux Enterprise Server 15 SP1-LTSS | kernel-source | Analysis |
SUSE Linux Enterprise Server 15 SP2 | kernel-source | Analysis |
SUSE Linux Enterprise Server 15 SP2-BCL | kernel-source | Analysis |
SUSE Linux Enterprise Server 15 SP2-LTSS | kernel-default | Analysis |
SUSE Linux Enterprise Server 15 SP2-LTSS | kernel-source | Analysis |
SUSE Linux Enterprise Server 15 SP3-BCL | kernel-source | Analysis |
SUSE Linux Enterprise Server 15-LTSS | kernel-default | Analysis |
SUSE Linux Enterprise Server 15-LTSS | kernel-source | Analysis |
SUSE Linux Enterprise Server for Raspberry Pi 12 SP2 | kernel-source | Analysis |
SUSE Linux Enterprise Server for SAP Applications 12 SP2 | kernel-source | Analysis |
SUSE Linux Enterprise Server for SAP Applications 12 SP4 | kernel-source | Analysis |
SUSE Linux Enterprise Server for SAP Applications 15 | kernel-source | Analysis |
SUSE Linux Enterprise Server for SAP Applications 15 SP1 | kernel-source | Analysis |
SUSE Linux Enterprise Server for SAP Applications 15 SP2 | kernel-source | Analysis |
SUSE Manager Proxy 4.0 | kernel-source | Analysis |
SUSE Manager Proxy 4.1 | kernel-source | Analysis |
SUSE Manager Proxy 4.2 | kernel-source | Analysis |
SUSE Manager Retail Branch Server 4.0 | kernel-source | Analysis |
SUSE Manager Retail Branch Server 4.1 | kernel-source | Analysis |
SUSE Manager Retail Branch Server 4.2 | kernel-source | Analysis |
SUSE Manager Server 4.0 | kernel-source | Analysis |
SUSE Manager Server 4.1 | kernel-source | Analysis |
SUSE Manager Server 4.2 | kernel-source | Analysis |
SUSE OpenStack Cloud 7 | kernel-source | Analysis |
SUSE OpenStack Cloud 9 | kernel-source | Analysis |
SUSE OpenStack Cloud Crowbar 9 | kernel-source | Analysis |
SUSE Real Time Module 15 SP3 | kernel-source-rt | Analysis |
SUSE Real Time Module 15 SP4 | kernel-source-rt | Analysis |
SUSE Real Time Module 15 SP5 | kernel-source-rt | Analysis |
openSUSE Leap 15.3 | kernel-source | Analysis |
openSUSE Leap 15.3 | kernel-source-rt | Analysis |
openSUSE Leap 15.4 | kernel-source | Analysis |
openSUSE Leap 15.4 | kernel-source-azure | Analysis |
openSUSE Leap 15.4 | kernel-source-rt | Analysis |
openSUSE Leap 15.5 | kernel-source | Analysis |
openSUSE Leap 15.5 | kernel-source-azure | Analysis |
openSUSE Leap 15.5 | kernel-source-rt | Analysis |
SUSE Timeline for this CVE
CVE page created: Wed Feb 26 04:20:18 2025CVE page last modified: Wed Feb 26 11:56:44 2025