diff options
| author | Konstantin Komarov <almaz.alexandrovich@paragon-software.com> | 2024-04-22 17:18:51 +0300 |
|---|---|---|
| committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2024-07-11 12:49:19 +0200 |
| commit | aa8b1d6073c14b9dbf2dea2b3f11dc7d721a9e29 (patch) | |
| tree | 91105e77aa6ed0266d48e9f32daeab3347f94b88 | |
| parent | 92e494a7568b60ae80d57fc0deafcaf3a4029ab3 (diff) | |
| download | linux-aa8b1d6073c14b9dbf2dea2b3f11dc7d721a9e29.tar.gz linux-aa8b1d6073c14b9dbf2dea2b3f11dc7d721a9e29.tar.bz2 linux-aa8b1d6073c14b9dbf2dea2b3f11dc7d721a9e29.zip | |
fs/ntfs3: Mark volume as dirty if xattr is broken
[ Upstream commit 24f6f5020b0b2c89c2cba5ec224547be95f753ee ]
Mark a volume as corrupted if the name length exceeds the space
occupied by ea.
Signed-off-by: Konstantin Komarov <almaz.alexandrovich@paragon-software.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
| -rw-r--r-- | fs/ntfs3/xattr.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/fs/ntfs3/xattr.c b/fs/ntfs3/xattr.c index b50010494e6d..72bceb8cd164 100644 --- a/fs/ntfs3/xattr.c +++ b/fs/ntfs3/xattr.c @@ -219,8 +219,11 @@ static ssize_t ntfs_list_ea(struct ntfs_inode *ni, char *buffer, if (!ea->name_len) break; - if (ea->name_len > ea_size) + if (ea->name_len > ea_size) { + ntfs_set_state(ni->mi.sbi, NTFS_DIRTY_ERROR); + err = -EINVAL; /* corrupted fs */ break; + } if (buffer) { /* Check if we can use field ea->name */ |
