summaryrefslogtreecommitdiff
path: root/mm
diff options
context:
space:
mode:
authorPeter Staubach <staubach@redhat.com>2006-02-17 13:52:36 -0800
committerChris Wright <chrisw@sous-sol.org>2006-03-01 14:36:35 -0800
commit8fef8ea2a1f28a7611ad0b8ff7b48ceb38db9535 (patch)
treeebf820dfff1eb8aadc354d5807d45821a48c6214 /mm
parent80a16577362b3eafa2f390d5e1ffb268464ccedb (diff)
[PATCH] fix deadlock in ext2
Fix a deadlock possible in the ext2 file system implementation. This deadlock occurs when a file is removed from an ext2 file system which was mounted with the "sync" mount option. The problem is that ext2_xattr_delete_inode() was invoking the routine, sync_dirty_buffer(), using a buffer head which was previously locked via lock_buffer(). The first thing that sync_dirty_buffer() does is to lock the buffer head that it was passed. It does this via lock_buffer(). Oops. The solution is to unlock the buffer head in ext2_xattr_delete_inode() before invoking sync_dirty_buffer(). This makes the code in ext2_xattr_delete_inode() obey the same locking rules as all other callers of sync_dirty_buffer() in the ext2 file system implementation. Signed-off-by: Peter Staubach <staubach@redhat.com> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'mm')
0 files changed, 0 insertions, 0 deletions