CVE Database
/

CVE-2024-47669

Back to search

CVE-2024-47669

Published: Oct 9, 2024

Modified: May 11, 2026

PUBLISHED

Description

In the Linux kernel, the following vulnerability has been resolved: nilfs2: fix state management in error path of log writing function After commit a694291a6211 ("nilfs2: separate wait function from nilfs_segctor_write") was applied, the log writing function nilfs_segctor_do_construct() was able to issue I/O requests continuously even if user data blocks were split into multiple logs across segments, but two potential flaws were introduced in its error handling. First, if nilfs_segctor_begin_construction() fails while creating the second or subsequent logs, the log writing function returns without calling nilfs_segctor_abort_construction(), so the writeback flag set on pages/folios will remain uncleared. This causes page cache operations to hang waiting for the writeback flag. For example, truncate_inode_pages_final(), which is called via nilfs_evict_inode() when an inode is evicted from memory, will hang. Second, the NILFS_I_COLLECTED flag set on normal inodes remain uncleared. As a result, if the next log write involves checkpoint creation, that's fine, but if a partial log write is performed that does not, inodes with NILFS_I_COLLECTED set are erroneously removed from the "sc_dirty_files" list, and their data and b-tree blocks may not be written to the device, corrupting the block mapping. Fix these issues by uniformly calling nilfs_segctor_abort_construction() on failure of each step in the loop in nilfs_segctor_do_construct(), having it clean up logs and segment usages according to progress, and correcting the conditions for calling nilfs_redirty_inodes() to ensure that the NILFS_I_COLLECTED flag is cleared.

VendorProductVersions

Linux

Linux

affected
a694291a6211537189c6080f77f63cdabfc9b63e - < 40a2757de2c376ef8a08d9ee9c81e77f3c750adf
affected
a694291a6211537189c6080f77f63cdabfc9b63e - < 036441e8438b29111fa75008f0ce305fb4e83c0a
affected
a694291a6211537189c6080f77f63cdabfc9b63e - < efdde00d4a1ef10bb71e09ebc67823a3d3ad725b
affected
a694291a6211537189c6080f77f63cdabfc9b63e - < 3e349d7191f0688fc9808ef24fd4e4b4ef5ca876
affected
a694291a6211537189c6080f77f63cdabfc9b63e - < 30562eff4a6dd35c4b5be9699ef61ad9f5f20a06

+3 more versions

Linux

Linux

affected
2.6.33
unaffected
0 - < 2.6.33
unaffected
4.19.322 - <= 4.19.*
unaffected
5.4.284 - <= 5.4.*
unaffected
5.10.226 - <= 5.10.*

+5 more versions

Security Training

Train your team to recognize and prevent security threats with our comprehensive security awareness program.

Start Training

Vulnerability Scanning

Discover vulnerabilities in your applications and infrastructure before attackers do.

Scan Now