summaryrefslogtreecommitdiffstats
path: root/fs/reiserfs/xattr.c
diff options
context:
space:
mode:
authorLepton Wu <ytht.net@gmail.com>2007-10-16 23:30:04 -0700
committerLinus Torvalds <torvalds@woody.linux-foundation.org>2007-10-17 08:42:58 -0700
commitfb46f341d9868fe993626536c7449c2a1aec62a3 (patch)
tree869b426000d9c4689110e08ff9419901a958ec7c /fs/reiserfs/xattr.c
parentb9ec0339d8e22cadf2d9d1b010b51dc53837dfb0 (diff)
downloadlinux-fb46f341d9868fe993626536c7449c2a1aec62a3.tar.gz
linux-fb46f341d9868fe993626536c7449c2a1aec62a3.tar.bz2
linux-fb46f341d9868fe993626536c7449c2a1aec62a3.zip
reiserfs: workaround for dead loop in finish_unfinished
There is possible dead loop in finish_unfinished function. In most situation, the call chain iput -> ... -> reiserfs_delete_inode -> remove_save_link will success. But for some reason such as data corruption, reiserfs_delete_inode fails on reiserfs_do_truncate -> search_for_position_by_key. Then remove_save_link won't be called. We always get the same "save_link_key" in the while loop in finish_unfinished function. The following patch adds a check for the possible dead loop and just remove save link when deap loop. [akpm@linux-foundation.org: cleanups] Signed-off-by: Lepton Wu <ytht.net@gmail.com> Cc: Chris Mason <chris.mason@oracle.com> Cc: Jeff Mahoney <jeffm@suse.com> Cc: "Vladimir V. Saveliev" <vs@namesys.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'fs/reiserfs/xattr.c')
0 files changed, 0 insertions, 0 deletions