diff options
author | Darrick J. Wong <darrick.wong@oracle.com> | 2015-06-21 21:10:51 -0400 |
---|---|---|
committer | Zefan Li <lizefan@huawei.com> | 2015-10-22 09:20:05 +0800 |
commit | 2ba0674bed6f8b830c9653015f431794d9c8efda (patch) | |
tree | 41cceb31b1a570a90c945b81876678f906c05ccf | |
parent | 52686b9264cfdff747380f1bb70d11274fd83060 (diff) | |
download | lwn-2ba0674bed6f8b830c9653015f431794d9c8efda.tar.gz lwn-2ba0674bed6f8b830c9653015f431794d9c8efda.zip |
ext4: don't retry file block mapping on bigalloc fs with non-extent file
commit 292db1bc6c105d86111e858859456bcb11f90f91 upstream.
ext4 isn't willing to map clusters to a non-extent file. Don't signal
this with an out of space error, since the FS will retry the
allocation (which didn't fail) forever. Instead, return EUCLEAN so
that the operation will fail immediately all the way back to userspace.
(The fix is either to run e2fsck -E bmap2extent, or to chattr +e the file.)
Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
Signed-off-by: Zefan Li <lizefan@huawei.com>
-rw-r--r-- | fs/ext4/indirect.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/ext4/indirect.c b/fs/ext4/indirect.c index 6dc6153dc462..f819837aa193 100644 --- a/fs/ext4/indirect.c +++ b/fs/ext4/indirect.c @@ -705,7 +705,7 @@ int ext4_ind_map_blocks(handle_t *handle, struct inode *inode, EXT4_FEATURE_RO_COMPAT_BIGALLOC)) { EXT4_ERROR_INODE(inode, "Can't allocate blocks for " "non-extent mapped inodes with bigalloc"); - return -ENOSPC; + return -EUCLEAN; } goal = ext4_find_goal(inode, map->m_lblk, partial); |