Skip to main content

CVE-2024-40998: Vulnerability in Linux Linux

Medium
VulnerabilityCVE-2024-40998cvecve-2024-40998
Published: Fri Jul 12 2024 (07/12/2024, 12:37:39 UTC)
Source: CVE
Vendor/Project: Linux
Product: Linux

Description

In the Linux kernel, the following vulnerability has been resolved: ext4: fix uninitialized ratelimit_state->lock access in __ext4_fill_super() In the following concurrency we will access the uninitialized rs->lock: ext4_fill_super ext4_register_sysfs // sysfs registered msg_ratelimit_interval_ms // Other processes modify rs->interval to // non-zero via msg_ratelimit_interval_ms ext4_orphan_cleanup ext4_msg(sb, KERN_INFO, "Errors on filesystem, " __ext4_msg ___ratelimit(&(EXT4_SB(sb)->s_msg_ratelimit_state) if (!rs->interval) // do nothing if interval is 0 return 1; raw_spin_trylock_irqsave(&rs->lock, flags) raw_spin_trylock(lock) _raw_spin_trylock __raw_spin_trylock spin_acquire(&lock->dep_map, 0, 1, _RET_IP_) lock_acquire __lock_acquire register_lock_class assign_lock_key dump_stack(); ratelimit_state_init(&sbi->s_msg_ratelimit_state, 5 * HZ, 10); raw_spin_lock_init(&rs->lock); // init rs->lock here and get the following dump_stack: ========================================================= INFO: trying to register non-static key. The code is fine but needs lockdep annotation, or maybe you didn't initialize this object before use? turning off the locking correctness validator. CPU: 12 PID: 753 Comm: mount Tainted: G E 6.7.0-rc6-next-20231222 #504 [...] Call Trace: dump_stack_lvl+0xc5/0x170 dump_stack+0x18/0x30 register_lock_class+0x740/0x7c0 __lock_acquire+0x69/0x13a0 lock_acquire+0x120/0x450 _raw_spin_trylock+0x98/0xd0 ___ratelimit+0xf6/0x220 __ext4_msg+0x7f/0x160 [ext4] ext4_orphan_cleanup+0x665/0x740 [ext4] __ext4_fill_super+0x21ea/0x2b10 [ext4] ext4_fill_super+0x14d/0x360 [ext4] [...] ========================================================= Normally interval is 0 until s_msg_ratelimit_state is initialized, so ___ratelimit() does nothing. But registering sysfs precedes initializing rs->lock, so it is possible to change rs->interval to a non-zero value via the msg_ratelimit_interval_ms interface of sysfs while rs->lock is uninitialized, and then a call to ext4_msg triggers the problem by accessing an uninitialized rs->lock. Therefore register sysfs after all initializations are complete to avoid such problems.

AI-Powered Analysis

AILast updated: 06/29/2025, 03:11:53 UTC

Technical Analysis

CVE-2024-40998 is a concurrency-related vulnerability in the Linux kernel's ext4 filesystem driver, specifically within the __ext4_fill_super() function. The issue arises due to the improper initialization order of the ratelimit_state structure's lock (rs->lock) and the registration of a sysfs interface (msg_ratelimit_interval_ms). Normally, the rs->lock is initialized before the sysfs interface is registered, ensuring safe concurrent access. However, in this vulnerability, the sysfs interface is registered before rs->lock is initialized, allowing other processes to modify rs->interval to a non-zero value via the sysfs interface while rs->lock remains uninitialized. Subsequently, when ext4_msg() is called (for example, during ext4_orphan_cleanup), it invokes ___ratelimit(), which attempts to acquire the uninitialized rs->lock using raw_spin_trylock_irqsave(). This leads to undefined behavior, including kernel warnings about registering a non-static key, lockdep errors, and potential kernel stack dumps. The root cause is a race condition and improper locking correctness validation due to the out-of-order initialization. Although this does not directly lead to privilege escalation or remote code execution, it can cause kernel instability, denial of service (via kernel panic or crash), and potential data integrity issues in the ext4 filesystem. The fix involves ensuring that rs->lock is properly initialized before registering the sysfs interface, thereby preventing concurrent access to an uninitialized lock. This vulnerability affects Linux kernel versions around 6.7.0-rc6-next-20231222 and potentially other versions with similar ext4 code paths. No known exploits are currently reported in the wild.

Potential Impact

For European organizations, this vulnerability poses a risk primarily to systems running Linux with ext4 filesystems, which are widespread in servers, desktops, and embedded devices. The impact includes potential kernel crashes or system instability triggered by local processes manipulating the sysfs interface before proper initialization. This could lead to denial of service conditions, affecting availability of critical services, especially in data centers, cloud environments, and enterprise infrastructure relying on Linux. While the vulnerability does not appear to allow privilege escalation or remote exploitation directly, the induced instability could be leveraged by attackers with local access to disrupt operations or cause data corruption. Organizations with high availability requirements, such as financial institutions, telecommunications providers, and public sector entities, may experience operational disruptions. Additionally, embedded Linux devices used in industrial control systems or IoT deployments across Europe could be affected if they use vulnerable kernel versions. The lack of known exploits reduces immediate risk, but the vulnerability should be addressed promptly to maintain system reliability and security posture.

Mitigation Recommendations

1. Apply the official Linux kernel patches that reorder the initialization sequence to ensure rs->lock is initialized before sysfs registration. Monitor Linux kernel mailing lists and vendor advisories for backported fixes. 2. For distributions that have not yet released patches, consider upgrading to the latest stable kernel versions that include the fix. 3. Restrict access to the sysfs interface msg_ratelimit_interval_ms to trusted users only, minimizing the risk of malicious or accidental manipulation. 4. Implement kernel lockdown or mandatory access control (e.g., SELinux, AppArmor) policies to limit local user capabilities to modify kernel parameters via sysfs. 5. Monitor system logs for kernel warnings related to lockdep or ratelimit_state issues as early indicators of attempted exploitation or instability. 6. In environments where kernel updates are delayed, consider isolating critical systems from untrusted users to reduce local attack surface. 7. Conduct thorough testing of kernel updates in staging environments to ensure no regressions affect ext4 filesystem stability.

Need more detailed analysis?Get Pro

Technical Details

Data Version
5.1
Assigner Short Name
Linux
Date Reserved
2024-07-12T12:17:45.607Z
Cisa Enriched
true
Cvss Version
null
State
PUBLISHED

Threat ID: 682d9827c4522896dcbe15fb

Added to database: 5/21/2025, 9:08:55 AM

Last enriched: 6/29/2025, 3:11:53 AM

Last updated: 8/17/2025, 5:32:25 PM

Views: 16

Actions

PRO

Updates to AI analysis are available only with a Pro account. Contact root@offseq.com for access.

Please log in to the Console to use AI analysis features.

Need enhanced features?

Contact root@offseq.com for Pro access with improved analysis and higher rate limits.

Latest Threats