udf: Fix BUG on corrupted inode
[ Upstream commit d288d95842f1503414b7eebce3773bac3390457e ] When inode is corrupted so that extent type is invalid, some functions (such as udf_truncate_extents()) will just BUG. Check that extent type is valid when loading the inode to memory. Reported-by: Anatoly Trosinenko <anatoly.trosinenko@gmail.com> Signed-off-by: Jan Kara <jack@suse.cz> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
0d997e1635
commit
ea59fcf67d
1 changed files with 6 additions and 0 deletions
|
@ -1364,6 +1364,12 @@ reread:
|
|||
|
||||
iinfo->i_alloc_type = le16_to_cpu(fe->icbTag.flags) &
|
||||
ICBTAG_FLAG_AD_MASK;
|
||||
if (iinfo->i_alloc_type != ICBTAG_FLAG_AD_SHORT &&
|
||||
iinfo->i_alloc_type != ICBTAG_FLAG_AD_LONG &&
|
||||
iinfo->i_alloc_type != ICBTAG_FLAG_AD_IN_ICB) {
|
||||
ret = -EIO;
|
||||
goto out;
|
||||
}
|
||||
iinfo->i_unique = 0;
|
||||
iinfo->i_lenEAttr = 0;
|
||||
iinfo->i_lenExtents = 0;
|
||||
|
|
Loading…
Add table
Reference in a new issue