linux/fs/f2fs
Jaegeuk Kim e8271fa390 f2fs: avoid BUG_ON when mouting corrupted image having garbage blocks
If the disk has some garbage blocks, F2FS is able to face with BUG_ON when
recovering direct node blocks.
This patch detects the error case and avoids that prior to reaching BUG_ON.

Alexey Khoroshilov addressed the potential security issues as follows.
"An ability to trigger a BUG_ON assert by mounting a crafted image is
usually considered as a local denial of service [1-3]. As far as I
understand, the reason is that some kernel data may become inconsistent
that can lead to further problems.

[1] http://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2011-3353
[2] http://www.openwall.com/lists/oss-security/2011/06/24/4
[3] http://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2011-2928
etc."

Reported-by: Andrey Tsyvarev <tsyvarev@ispras.ru>
Cc: Alexey Khoroshilov <khoroshilov@ispras.ru>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2014-05-07 10:21:55 +09:00
..
acl.c f2fs: check the acl's validity before setting 2014-04-07 12:18:30 +09:00
acl.h f2fs: use generic posix ACL infrastructure 2014-01-25 23:58:19 -05:00
checkpoint.c f2fs: add static to get_max_meta_blks 2014-05-07 10:21:55 +09:00
data.c f2fs: call redirty_page_for_writepage 2014-05-07 10:21:54 +09:00
debug.c f2fs: remove unnecessary threshold 2014-03-20 22:10:09 +09:00
dir.c f2fs: introduce fi->i_sem to protect fi's info 2014-03-20 22:10:11 +09:00
f2fs.h f2fs: add available_nids to fix handling max_nid correctly 2014-05-07 10:21:55 +09:00
file.c Merge branch 'akpm' (incoming from Andrew) 2014-04-07 16:38:06 -07:00
gc.c f2fs: remove the unused ctor argument of f2fs_kmem_cache_create() 2014-03-10 18:45:14 +09:00
gc.h f2fs: add a sysfs entry to control max_victim_search 2014-01-08 13:45:08 +09:00
hash.c f2fs: unify string length declarations and usage 2012-12-28 11:27:53 +09:00
inline.c f2fs: fix to unlock f2fs_lock at the omitted error case 2014-05-07 10:21:54 +09:00
inode.c f2fs: atomically set inode->i_flags in f2fs_set_inode_flags() 2014-05-07 10:21:54 +09:00
Kconfig f2fs: introduce CONFIG_F2FS_CHECK_FS for BUG_ON control 2013-10-29 15:43:01 +09:00
Makefile f2fs: key functions to handle inline data 2013-12-26 20:40:09 +09:00
namei.c f2fs: fix wrong statistics of inline data 2014-04-07 12:40:58 +09:00
node.c f2fs: avoid BUG_ON when mouting corrupted image having garbage blocks 2014-05-07 10:21:55 +09:00
node.h f2fs: introduce raw_nat_from_node_info() to simplfy codes 2014-05-07 10:21:55 +09:00
recovery.c f2fs: remove costly dirty_dir_inode operations 2014-05-07 10:21:54 +09:00
segment.c f2fs: add the flush_merge handle in the remount flow 2014-05-07 10:21:55 +09:00
segment.h f2fs: change reclaim rate in percentage 2014-03-20 22:10:10 +09:00
super.c f2fs: add the flush_merge handle in the remount flow 2014-05-07 10:21:55 +09:00
xattr.c f2fs: avoid unneeded lookup when xattr name length is too long 2014-04-01 18:54:24 +09:00
xattr.h f2fs: use generic posix ACL infrastructure 2014-01-25 23:58:19 -05:00