summaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorSurbhi Palande <surbhi.palande@canonical.com>2009-12-14 09:53:52 -0500
committerTheodore Ts'o <tytso@mit.edu>2009-12-14 09:53:52 -0500
commit034fb4c95fc0fed4ec4a50778127b92c6f2aec01 (patch)
tree663bf0c4d0123f6aeeda8fd7124a5921433101ba /fs
parent51b7e3c9fbe7d22d4e355101e9a73b44fc5c9feb (diff)
downloadlinux-stable-034fb4c95fc0fed4ec4a50778127b92c6f2aec01.tar.gz
linux-stable-034fb4c95fc0fed4ec4a50778127b92c6f2aec01.tar.bz2
linux-stable-034fb4c95fc0fed4ec4a50778127b92c6f2aec01.zip
ext4: replace BUG() with return -EIO in ext4_ext_get_blocks
This patch fixes the Kernel BZ #14286. When the address of an extent corresponding to a valid block is corrupted, a -EIO should be reported instead of a BUG(). This situation should not normally not occur except in the case of a corrupted filesystem. If however it does, then the system should not panic directly but depending on the mount time options appropriate action should be taken. If the mount options so permit, the I/O should be gracefully aborted by returning a -EIO. http://bugzilla.kernel.org/show_bug.cgi?id=14286 Signed-off-by: Surbhi Palande <surbhi.palande@canonical.com> Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
Diffstat (limited to 'fs')
-rw-r--r--fs/ext4/extents.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c
index 3a7928f825e4..8fd6c567964a 100644
--- a/fs/ext4/extents.c
+++ b/fs/ext4/extents.c
@@ -3190,7 +3190,13 @@ int ext4_ext_get_blocks(handle_t *handle, struct inode *inode,
* this situation is possible, though, _during_ tree modification;
* this is why assert can't be put in ext4_ext_find_extent()
*/
- BUG_ON(path[depth].p_ext == NULL && depth != 0);
+ if (path[depth].p_ext == NULL && depth != 0) {
+ ext4_error(inode->i_sb, __func__, "bad extent address "
+ "inode: %lu, iblock: %d, depth: %d",
+ inode->i_ino, iblock, depth);
+ err = -EIO;
+ goto out2;
+ }
eh = path[depth].p_hdr;
ex = path[depth].p_ext;