]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
udf: Make sure i_lenExtents is uptodate on inode eviction
authorJan Kara <jack@suse.cz>
Wed, 7 May 2025 09:49:41 +0000 (11:49 +0200)
committerJan Kara <jack@suse.cz>
Wed, 7 May 2025 10:04:07 +0000 (12:04 +0200)
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>
fs/udf/truncate.c

index 4f33a4a4888613b5f7a9d00d7e01565af9cc2e07..b4071c9cf8c951299645e7af4dab41eb4f29633c 100644 (file)
@@ -115,7 +115,7 @@ void udf_truncate_tail_extent(struct inode *inode)
        }
        /* This inode entry is in-memory only and thus we don't have to mark
         * the inode dirty */
-       if (ret == 0)
+       if (ret >= 0)
                iinfo->i_lenExtents = inode->i_size;
        brelse(epos.bh);
 }