Hello all,

i've seen two possible circular locking dependencies with my bluetooth dialup
setup. The dmesg outputs are attached.

Any idea?

I'll check, if i can reproduce this dmesg output.
Please let me know, if you need additional infos.

Best regards,
Oliver
[ 1003.760488] PPP generic driver version 2.4.2
[ 1008.042682] Bluetooth: TIOCGSERIAL is not supported
[ 1008.850769] Bluetooth: TIOCGSERIAL is not supported
[ 1042.449682] PPP BSD Compression module registered
[ 1042.458694] PPP Deflate Compression module registered
[ 1128.563091] 
[ 1128.563097] ======================================================
[ 1128.563099] [ INFO: possible circular locking dependency detected ]
[ 1128.563103] 3.7.0 #195 Not tainted
[ 1128.563105] -------------------------------------------------------
[ 1128.563107] kworker/1:1/31 is trying to acquire lock:
[ 1128.563109]  (&tty->legacy_mutex){+.+.+.}, at: [<c150f286>] 
tty_lock_nested+0x36/0x80
[ 1128.563123] 
[ 1128.563123] but task is already holding lock:
[ 1128.563125]  ((&tty->hangup_work)){+.+...}, at: [<c1052983>] 
process_one_work+0x123/0x4d0
[ 1128.563135] 
[ 1128.563135] which lock already depends on the new lock.
[ 1128.563135] 
[ 1128.563138] 
[ 1128.563138] the existing dependency chain (in reverse order) is:
[ 1128.563140] 
[ 1128.563140] -> #2 ((&tty->hangup_work)){+.+...}:
[ 1128.563145]        [<c1085809>] lock_acquire+0x79/0xf0
[ 1128.563151]        [<c1053168>] flush_work+0x48/0x250
[ 1128.563155]        [<c1294a56>] tty_ldisc_flush_works+0x16/0x30
[ 1128.563160]        [<c1295941>] tty_ldisc_release+0x21/0x70
[ 1128.563164]        [<c128ee7c>] tty_release+0x37c/0x4a0
[ 1128.563170]        [<c11175cc>] __fput+0xcc/0x1f0
[ 1128.563176]        [<c11176fd>] ____fput+0xd/0x10
[ 1128.563179]        [<c1056eb9>] task_work_run+0x89/0xa0
[ 1128.563184]        [<c1002b11>] do_notify_resume+0x51/0x80
[ 1128.563189]        [<c150f578>] work_notifysig+0x29/0x31
[ 1128.563193] 
[ 1128.563193] -> #1 (&tty->legacy_mutex/1){+.+...}:
[ 1128.563199]        [<c1085809>] lock_acquire+0x79/0xf0
[ 1128.563203]        [<c150c1fa>] mutex_lock_nested+0x4a/0x2f0
[ 1128.563208]        [<c150f286>] tty_lock_nested+0x36/0x80
[ 1128.563212]        [<c150f319>] tty_lock_pair+0x29/0x70
[ 1128.563216]        [<c128ec30>] tty_release+0x130/0x4a0
[ 1128.563220]        [<c11175cc>] __fput+0xcc/0x1f0
[ 1128.563224]        [<c11176fd>] ____fput+0xd/0x10
[ 1128.563227]        [<c1056eb9>] task_work_run+0x89/0xa0
[ 1128.563231]        [<c1002b11>] do_notify_resume+0x51/0x80
[ 1128.563235]        [<c150f578>] work_notifysig+0x29/0x31
[ 1128.563239] 
[ 1128.563239] -> #0 (&tty->legacy_mutex){+.+.+.}:
[ 1128.563243]        [<c10852ae>] __lock_acquire+0x165e/0x1710
[ 1128.563248]        [<c1085809>] lock_acquire+0x79/0xf0
[ 1128.563252]        [<c150c1fa>] mutex_lock_nested+0x4a/0x2f0
[ 1128.563255]        [<c150f286>] tty_lock_nested+0x36/0x80
[ 1128.563259]        [<c150f2df>] tty_lock+0xf/0x20
[ 1128.563263]        [<c128d904>] __tty_hangup+0x54/0x430
[ 1128.563267]        [<c128dcf2>] do_tty_hangup+0x12/0x20
[ 1128.563272]        [<c1052a02>] process_one_work+0x1a2/0x4d0
[ 1128.563275]        [<c1054509>] worker_thread+0x119/0x3b0
[ 1128.563279]        [<c105a1ff>] kthread+0x9f/0xb0
[ 1128.563283]        [<c150fc37>] ret_from_kernel_thread+0x1b/0x28
[ 1128.563287] 
[ 1128.563287] other info that might help us debug this:
[ 1128.563287] 
[ 1128.563290] Chain exists of:
[ 1128.563290]   &tty->legacy_mutex --> &tty->legacy_mutex/1 --> 
(&tty->hangup_work)
[ 1128.563290] 
[ 1128.563297]  Possible unsafe locking scenario:
[ 1128.563297] 
[ 1128.563299]        CPU0                    CPU1
[ 1128.563301]        ----                    ----
[ 1128.563302]   lock((&tty->hangup_work));
[ 1128.563305]                                lock(&tty->legacy_mutex/1);
[ 1128.563309]                                lock((&tty->hangup_work));
[ 1128.563312]   lock(&tty->legacy_mutex);
[ 1128.563315] 
[ 1128.563315]  *** DEADLOCK ***
[ 1128.563315] 
[ 1128.563319] 2 locks held by kworker/1:1/31:
[ 1128.563320]  #0:  (events){.+.+.+}, at: [<c1052983>] 
process_one_work+0x123/0x4d0
[ 1128.563328]  #1:  ((&tty->hangup_work)){+.+...}, at: [<c1052983>] 
process_one_work+0x123/0x4d0
[ 1128.563335] 
[ 1128.563335] stack backtrace:
[ 1128.563339] Pid: 31, comm: kworker/1:1 Not tainted 3.7.0 #195
[ 1128.563341] Call Trace:
[ 1128.563348]  [<c1506992>] print_circular_bug+0x1af/0x1b9
[ 1128.563352]  [<c10852ae>] __lock_acquire+0x165e/0x1710
[ 1128.563358]  [<c1085809>] lock_acquire+0x79/0xf0
[ 1128.563362]  [<c150f286>] ? tty_lock_nested+0x36/0x80
[ 1128.563366]  [<c150c1fa>] mutex_lock_nested+0x4a/0x2f0
[ 1128.563370]  [<c150f286>] ? tty_lock_nested+0x36/0x80
[ 1128.563375]  [<c128d8d2>] ? __tty_hangup+0x22/0x430
[ 1128.563379]  [<c150f286>] tty_lock_nested+0x36/0x80
[ 1128.563383]  [<c150f2df>] tty_lock+0xf/0x20
[ 1128.563388]  [<c128d904>] __tty_hangup+0x54/0x430
[ 1128.563391]  [<c1052983>] ? process_one_work+0x123/0x4d0
[ 1128.563396]  [<c128dcf2>] do_tty_hangup+0x12/0x20
[ 1128.563400]  [<c1052a02>] process_one_work+0x1a2/0x4d0
[ 1128.563403]  [<c1052983>] ? process_one_work+0x123/0x4d0
[ 1128.563407]  [<c10545ae>] ? worker_thread+0x1be/0x3b0
[ 1128.563411]  [<c128dce0>] ? __tty_hangup+0x430/0x430
[ 1128.563415]  [<c1054509>] worker_thread+0x119/0x3b0
[ 1128.563419]  [<c10543f0>] ? __next_gcwq_cpu+0x60/0x60
[ 1128.563424]  [<c105a1ff>] kthread+0x9f/0xb0
[ 1128.563428]  [<c150fc37>] ret_from_kernel_thread+0x1b/0x28
[ 1128.563433]  [<c105a160>] ? kthread_create_on_node+0xe0/0xe0
[   14.711344] Bluetooth: BNEP (Ethernet Emulation) ver 1.3
[   14.713505] Bluetooth: BNEP socket layer initialized
[   14.714497] Bluetooth: RFCOMM TTY layer initialized
[   14.714511] Bluetooth: RFCOMM socket layer initialized
[   14.714512] Bluetooth: RFCOMM ver 1.11
[   15.385668] input: ACPI Virtual Keyboard Device as 
/devices/virtual/input/input17
[   57.826528] PPP generic driver version 2.4.2
[   66.309295] 
[   66.309301] ======================================================
[   66.309303] [ INFO: possible circular locking dependency detected ]
[   66.309307] 3.7.0 #195 Not tainted
[   66.309308] -------------------------------------------------------
[   66.309310] kworker/2:1/35 is trying to acquire lock:
[   66.309313]  (&tty->legacy_mutex){+.+.+.}, at: [<c150f286>] 
tty_lock_nested+0x36/0x80
[   66.309328] 
[   66.309328] but task is already holding lock:
[   66.309330]  ((&tty->hangup_work)){+.+...}, at: [<c1052983>] 
process_one_work+0x123/0x4d0
[   66.309340] 
[   66.309340] which lock already depends on the new lock.
[   66.309340] 
[   66.309343] 
[   66.309343] the existing dependency chain (in reverse order) is:
[   66.309345] 
[   66.309345] -> #2 ((&tty->hangup_work)){+.+...}:
[   66.309351]        [<c1085809>] lock_acquire+0x79/0xf0
[   66.309357]        [<c1053168>] flush_work+0x48/0x250
[   66.309360]        [<c1294a56>] tty_ldisc_flush_works+0x16/0x30
[   66.309366]        [<c1295941>] tty_ldisc_release+0x21/0x70
[   66.309370]        [<c128ee7c>] tty_release+0x37c/0x4a0
[   66.309376]        [<c11175cc>] __fput+0xcc/0x1f0
[   66.309381]        [<c11176fd>] ____fput+0xd/0x10
[   66.309385]        [<c1056eb9>] task_work_run+0x89/0xa0
[   66.309390]        [<c1002b11>] do_notify_resume+0x51/0x80
[   66.309394]        [<c150f578>] work_notifysig+0x29/0x31
[   66.309399] 
[   66.309399] -> #1 (&tty->legacy_mutex/1){+.+...}:
[   66.309405]        [<c1085809>] lock_acquire+0x79/0xf0
[   66.309409]        [<c150c1fa>] mutex_lock_nested+0x4a/0x2f0
[   66.309413]        [<c150f286>] tty_lock_nested+0x36/0x80
[   66.309417]        [<c150f319>] tty_lock_pair+0x29/0x70
[   66.309421]        [<c128ec30>] tty_release+0x130/0x4a0
[   66.309425]        [<c11175cc>] __fput+0xcc/0x1f0
[   66.309429]        [<c11176fd>] ____fput+0xd/0x10
[   66.309432]        [<c1056eb9>] task_work_run+0x89/0xa0
[   66.309436]        [<c1002b11>] do_notify_resume+0x51/0x80
[   66.309440]        [<c150f578>] work_notifysig+0x29/0x31
[   66.309444] 
[   66.309444] -> #0 (&tty->legacy_mutex){+.+.+.}:
[   66.309448]        [<c10852ae>] __lock_acquire+0x165e/0x1710
[   66.309453]        [<c1085809>] lock_acquire+0x79/0xf0
[   66.309456]        [<c150c1fa>] mutex_lock_nested+0x4a/0x2f0
[   66.309460]        [<c150f286>] tty_lock_nested+0x36/0x80
[   66.309464]        [<c150f2df>] tty_lock+0xf/0x20
[   66.309468]        [<c128d904>] __tty_hangup+0x54/0x430
[   66.309472]        [<c128dcf2>] do_tty_hangup+0x12/0x20
[   66.309476]        [<c1052a02>] process_one_work+0x1a2/0x4d0
[   66.309480]        [<c1054509>] worker_thread+0x119/0x3b0
[   66.309484]        [<c105a1ff>] kthread+0x9f/0xb0
[   66.309488]        [<c150fc37>] ret_from_kernel_thread+0x1b/0x28
[   66.309492] 
[   66.309492] other info that might help us debug this:
[   66.309492] 
[   66.309495] Chain exists of:
[   66.309495]   &tty->legacy_mutex --> &tty->legacy_mutex/1 --> 
(&tty->hangup_work)
[   66.309495] 
[   66.309502]  Possible unsafe locking scenario:
[   66.309502] 
[   66.309504]        CPU0                    CPU1
[   66.309506]        ----                    ----
[   66.309507]   lock((&tty->hangup_work));
[   66.309510]                                lock(&tty->legacy_mutex/1);
[   66.309514]                                lock((&tty->hangup_work));
[   66.309517]   lock(&tty->legacy_mutex);
[   66.309520] 
[   66.309520]  *** DEADLOCK ***
[   66.309520] 
[   66.309524] 2 locks held by kworker/2:1/35:
[   66.309525]  #0:  (events){.+.+.+}, at: [<c1052983>] 
process_one_work+0x123/0x4d0
[   66.309532]  #1:  ((&tty->hangup_work)){+.+...}, at: [<c1052983>] 
process_one_work+0x123/0x4d0
[   66.309539] 
[   66.309539] stack backtrace:
[   66.309543] Pid: 35, comm: kworker/2:1 Not tainted 3.7.0 #195
[   66.309545] Call Trace:
[   66.309552]  [<c1506992>] print_circular_bug+0x1af/0x1b9
[   66.309556]  [<c10852ae>] __lock_acquire+0x165e/0x1710
[   66.309562]  [<c1085809>] lock_acquire+0x79/0xf0
[   66.309566]  [<c150f286>] ? tty_lock_nested+0x36/0x80
[   66.309571]  [<c150c1fa>] mutex_lock_nested+0x4a/0x2f0
[   66.309575]  [<c150f286>] ? tty_lock_nested+0x36/0x80
[   66.309579]  [<c128d8d2>] ? __tty_hangup+0x22/0x430
[   66.309583]  [<c150f286>] tty_lock_nested+0x36/0x80
[   66.309588]  [<c150f2df>] tty_lock+0xf/0x20
[   66.309592]  [<c128d904>] __tty_hangup+0x54/0x430
[   66.309596]  [<c1052983>] ? process_one_work+0x123/0x4d0
[   66.309600]  [<c128dcf2>] do_tty_hangup+0x12/0x20
[   66.309604]  [<c1052a02>] process_one_work+0x1a2/0x4d0
[   66.309607]  [<c1052983>] ? process_one_work+0x123/0x4d0
[   66.309611]  [<c10545ae>] ? worker_thread+0x1be/0x3b0
[   66.309616]  [<c128dce0>] ? __tty_hangup+0x430/0x430
[   66.309620]  [<c1054509>] worker_thread+0x119/0x3b0
[   66.309624]  [<c10543f0>] ? __next_gcwq_cpu+0x60/0x60
[   66.309628]  [<c105a1ff>] kthread+0x9f/0xb0
[   66.309633]  [<c150fc37>] ret_from_kernel_thread+0x1b/0x28
[   66.309637]  [<c105a160>] ? kthread_create_on_node+0xe0/0xe0

Reply via email to