reiserfs locking (v2)
From: Sergey Senozhatsky
Date: Fri Jul 02 2010 - 05:49:18 EST
Code with munmap produces:
[ 54.152356]
[ 54.152358] =======================================================
[ 54.152363] [ INFO: possible circular locking dependency detected ]
[ 54.152367] 2.6.35-rc3-dbg-git6-00502-g94feaba-dirty #65
[ 54.152371] -------------------------------------------------------
[ 54.152374] a.out/4044 is trying to acquire lock:
[ 54.152378] (&sb->s_type->i_mutex_key#10){+.+.+.}, at: [<c10f1d4e>] reiserfs_file_release+0x11d/0x344
[ 54.152394]
[ 54.152395] but task is already holding lock:
[ 54.152398] (&mm->mmap_sem){++++++}, at: [<c1091b7f>] sys_munmap+0x26/0x42
[ 54.152408]
[ 54.152409] which lock already depends on the new lock.
[ 54.152410]
[ 54.152413]
[ 54.152414] the existing dependency chain (in reverse order) is:
[ 54.152417]
[ 54.152418] -> #1 (&mm->mmap_sem){++++++}:
[ 54.152425] [<c104f566>] lock_acquire+0x59/0x70
[ 54.152433] [<c108cf70>] might_fault+0x53/0x70
[ 54.152439] [<c1185418>] copy_to_user+0x30/0x48
[ 54.152445] [<c10afaf9>] filldir64+0x95/0xc9
[ 54.152451] [<c10f255c>] reiserfs_readdir_dentry+0x35d/0x4d9
[ 54.152457] [<c10f26ea>] reiserfs_readdir+0x12/0x17
[ 54.152463] [<c10afd17>] vfs_readdir+0x6d/0x92
[ 54.152468] [<c10afe91>] sys_getdents64+0x63/0xa2
[ 54.152473] [<c10027d3>] sysenter_do_call+0x12/0x32
[ 54.152480]
[ 54.152481] -> #0 (&sb->s_type->i_mutex_key#10){+.+.+.}:
[ 54.152488] [<c104ef5c>] __lock_acquire+0x96d/0xbe1
[ 54.152494] [<c104f566>] lock_acquire+0x59/0x70
[ 54.152500] [<c12c5674>] __mutex_lock_common+0x39/0x36b
[ 54.152507] [<c12c59e0>] mutex_lock_nested+0x12/0x15
[ 54.152512] [<c10f1d4e>] reiserfs_file_release+0x11d/0x344
[ 54.152518] [<c10a5805>] fput+0xe0/0x16a
[ 54.152524] [<c1090c9e>] remove_vma+0x28/0x47
[ 54.152529] [<c1091a60>] do_munmap+0x1e8/0x200
[ 54.152535] [<c1091b8b>] sys_munmap+0x32/0x42
[ 54.152540] [<c10027d3>] sysenter_do_call+0x12/0x32
[ 54.152546]
[ 54.152546] other info that might help us debug this:
[ 54.152548]
[ 54.152552] 1 lock held by a.out/4044:
[ 54.152554] #0: (&mm->mmap_sem){++++++}, at: [<c1091b7f>] sys_munmap+0x26/0x42
[ 54.152563]
[ 54.152564] stack backtrace:
[ 54.152569] Pid: 4044, comm: a.out Not tainted 2.6.35-rc3-dbg-git6-00502-g94feaba-dirty #65
[ 54.152572] Call Trace:
[ 54.152577] [<c12c48f3>] ? printk+0xf/0x11
[ 54.152583] [<c104dc09>] print_circular_bug+0x8a/0x96
[ 54.152589] [<c104ef5c>] __lock_acquire+0x96d/0xbe1
[ 54.152595] [<c104e462>] ? mark_lock+0x26/0x1b3
[ 54.152601] [<c104f566>] lock_acquire+0x59/0x70
[ 54.152607] [<c10f1d4e>] ? reiserfs_file_release+0x11d/0x344
[ 54.152612] [<c12c5674>] __mutex_lock_common+0x39/0x36b
[ 54.152618] [<c10f1d4e>] ? reiserfs_file_release+0x11d/0x344
[ 54.152624] [<c12c59e0>] mutex_lock_nested+0x12/0x15
[ 54.152629] [<c10f1d4e>] ? reiserfs_file_release+0x11d/0x344
[ 54.152634] [<c10f1d4e>] reiserfs_file_release+0x11d/0x344
[ 54.152640] [<c108d77d>] ? free_pgd_range+0x96/0x12f
[ 54.152646] [<c10a57b5>] ? fput+0x90/0x16a
[ 54.152651] [<c10a5805>] fput+0xe0/0x16a
[ 54.152656] [<c1090c9e>] remove_vma+0x28/0x47
[ 54.152661] [<c1091811>] ? arch_unmap_area_topdown+0x0/0x18
[ 54.152666] [<c1091a60>] do_munmap+0x1e8/0x200
[ 54.152672] [<c1091b8b>] sys_munmap+0x32/0x42
[ 54.152677] [<c10027d3>] sysenter_do_call+0x12/0x32
Sergey
Attachment:
pgp00000.pgp
Description: PGP signature