diff options
author | Jan Kara <jack@suse.cz> | 2025-05-07 11:49:41 +0200 |
---|---|---|
committer | Jan Kara <jack@suse.cz> | 2025-05-07 12:04:07 +0200 |
commit | 55dd5b4db3bf04cf077a8d1712f6295d4517c337 (patch) | |
tree | 23e90b1ace06a98782b0b5657ca4cb61135a7122 /rust/helpers/build_bug.c | |
parent | 0d8d44db295ccad20052d6301ef49ff01fb8ae2d (diff) |
udf: Make sure i_lenExtents is uptodate on inode eviction
UDF maintains total length of all extents in i_lenExtents. Generally we
keep extent lengths (and thus i_lenExtents) block aligned because it
makes the file appending logic simpler. However the standard mandates
that the inode size must match the length of all extents and thus we
trim the last extent when closing the file. To catch possible bugs we
also verify that i_lenExtents matches i_size when evicting inode from
memory. Commit b405c1e58b73 ("udf: refactor udf_next_aext() to handle
error") however broke the code updating i_lenExtents and thus
udf_evict_inode() ended up spewing lots of errors about incorrectly
sized extents although the extents were actually sized properly. Fix the
updating of i_lenExtents to silence the errors.
Fixes: b405c1e58b73 ("udf: refactor udf_next_aext() to handle error")
CC: stable@vger.kernel.org
Signed-off-by: Jan Kara <jack@suse.cz>
Diffstat (limited to 'rust/helpers/build_bug.c')
0 files changed, 0 insertions, 0 deletions