[PATCH] Bluetooth: Fix inconsistent lock state with RFCOMM

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



From: Gustavo F. Padovan <padovan@xxxxxxxxxxxxxx>

When receiving a rfcomm connection with the old dund deamon the following
inconsistent lock state happens:

[  811.702999] =================================
[  811.702999] [ INFO: inconsistent lock state ]
[  811.702999] 2.6.35-rc1-01743-g41069ad-dirty #1
[  811.702999] ---------------------------------
[  811.702999] inconsistent {IN-SOFTIRQ-W} -> {SOFTIRQ-ON-W} usage.
[  811.702999] krfcommd/3892 [HC0[0]:SC0[0]:HE1:SE1] takes:
[  811.702999]  (slock-AF_BLUETOOTH){+.?...}, at: [<ffffffffa0189b56>] rfcomm_sk_state_change+0x46/0x170 [rfcomm]
[  811.702999] {IN-SOFTIRQ-W} state was registered at:
[  811.702999]   [<ffffffff8108dfa6>] __lock_acquire+0x5b6/0x1560
[  811.702999]   [<ffffffff8108efaa>] lock_acquire+0x5a/0x70
[  811.702999]   [<ffffffff81387b2c>] _raw_spin_lock+0x2c/0x40
[  811.702999]   [<ffffffffa0043092>] 0xffffffffa0043092
[  811.702999]   [<ffffffffa0044a3f>] 0xffffffffa0044a3f
[  811.702999]   [<ffffffffa0047183>] 0xffffffffa0047183
[  811.702999]   [<ffffffffa004798b>] 0xffffffffa004798b
[  811.702999]   [<ffffffffa000db4b>] 0xffffffffa000db4b
[  811.702999]   [<ffffffff81067efb>] tasklet_action+0xcb/0xe0
[  811.702999]   [<ffffffff810685ee>] __do_softirq+0xae/0x150
[  811.702999]   [<ffffffff81029c0c>] call_softirq+0x1c/0x30
[  811.702999]   [<ffffffff8102bd75>] do_softirq+0x75/0xb0
[  811.702999]   [<ffffffff8106823d>] irq_exit+0x8d/0xa0
[  811.702999]   [<ffffffff8102b330>] do_IRQ+0x70/0xf0
[  811.702999]   [<ffffffff81388513>] ret_from_intr+0x0/0xf
[  811.702999]   [<ffffffff81027dfa>] cpu_idle+0x5a/0xb0
[  811.702999]   [<ffffffff81382934>] start_secondary+0x211/0x254
[  811.702999] irq event stamp: 411
[  811.702999] hardirqs last  enabled at (411): [<ffffffff81068432>] local_bh_enable_ip+0x82/0xe0
[  811.702999] hardirqs last disabled at (409): [<ffffffff8106860e>] __do_softirq+0xce/0x150
[  811.702999] softirqs last  enabled at (410): [<ffffffff8106863e>] __do_softirq+0xfe/0x150
[  811.702999] softirqs last disabled at (391): [<ffffffff81029c0c>] call_softirq+0x1c/0x30
[  811.702999]
[  811.702999] other info that might help us debug this:
[  811.702999] 2 locks held by krfcommd/3892:
[  811.702999]  #0:  (rfcomm_mutex){+.+.+.}, at: [<ffffffffa0188744>] rfcomm_run+0x174/0xb20 [rfcomm]
[  811.702999]  #1:  (&(&d->lock)->rlock){+.+...}, at: [<ffffffffa0186223>] rfcomm_dlc_accept+0x53/0x100 [rfcomm]
[  811.702999]
[  811.702999] stack backtrace:
[  811.702999] Pid: 3892, comm: krfcommd Tainted: G        W   2.6.35-rc1-01743-g41069ad-dirty #1
[  811.702999] Call Trace:
[  811.702999]  [<ffffffff8108c541>] print_usage_bug+0x171/0x180
[  811.702999]  [<ffffffff8108d323>] mark_lock+0x333/0x400
[  811.702999]  [<ffffffff8108e02a>] __lock_acquire+0x63a/0x1560
[  811.702999]  [<ffffffff8108e515>] ? __lock_acquire+0xb25/0x1560
[  811.702999]  [<ffffffff8108efaa>] lock_acquire+0x5a/0x70
[  811.702999]  [<ffffffffa0189b56>] ? rfcomm_sk_state_change+0x46/0x170 [rfcomm]
[  811.702999]  [<ffffffff81387b2c>] _raw_spin_lock+0x2c/0x40
[  811.702999]  [<ffffffffa0189b56>] ? rfcomm_sk_state_change+0x46/0x170 [rfcomm]
[  811.702999]  [<ffffffffa0189b56>] rfcomm_sk_state_change+0x46/0x170 [rfcomm]
[  811.702999]  [<ffffffffa0186239>] rfcomm_dlc_accept+0x69/0x100 [rfcomm]
[  811.702999]  [<ffffffffa0186a49>] rfcomm_check_accept+0x59/0xd0 [rfcomm]
[  811.702999]  [<ffffffffa0187cab>] rfcomm_recv_frame+0x9fb/0x1320 [rfcomm]
[  811.702999]  [<ffffffff8138827b>] ? _raw_spin_unlock_irqrestore+0x3b/0x60
[  811.702999]  [<ffffffff8108d72d>] ? trace_hardirqs_on_caller+0x13d/0x180
[  811.702999]  [<ffffffff8108d77d>] ? trace_hardirqs_on+0xd/0x10
[  811.702999]  [<ffffffffa01887f1>] rfcomm_run+0x221/0xb20 [rfcomm]
[  811.702999]  [<ffffffff81385667>] ? schedule+0x267/0x5d0
[  811.702999]  [<ffffffffa01885d0>] ? rfcomm_run+0x0/0xb20 [rfcomm]
[  811.702999]  [<ffffffff8107afae>] kthread+0x8e/0xa0
[  811.702999]  [<ffffffff81029b14>] kernel_thread_helper+0x4/0x10
[  811.702999]  [<ffffffff813885bc>] ? restore_args+0x0/0x30
[  811.702999]  [<ffffffff8107af20>] ? kthread+0x0/0xa0
[  811.702999]  [<ffffffff81029b10>] ? kernel_thread_helper+0x0/0x10

Signed-off-by: Gustavo F. Padovan <padovan@xxxxxxxxxxxxxx>
---
 net/bluetooth/rfcomm/sock.c |    6 ++++--
 1 files changed, 4 insertions(+), 2 deletions(-)

diff --git a/net/bluetooth/rfcomm/sock.c b/net/bluetooth/rfcomm/sock.c
index 44a6232..30cd80b 100644
--- a/net/bluetooth/rfcomm/sock.c
+++ b/net/bluetooth/rfcomm/sock.c
@@ -82,12 +82,14 @@ static void rfcomm_sk_data_ready(struct rfcomm_dlc *d, struct sk_buff *skb)
 static void rfcomm_sk_state_change(struct rfcomm_dlc *d, int err)
 {
 	struct sock *sk = d->owner, *parent;
+	unsigned long flags;
+
 	if (!sk)
 		return;
 
 	BT_DBG("dlc %p state %ld err %d", d, d->state, err);
 
-	bh_lock_sock(sk);
+	spin_lock_irqsave(&sk->sk_lock.slock, flags);
 
 	if (err)
 		sk->sk_err = err;
@@ -107,7 +109,7 @@ static void rfcomm_sk_state_change(struct rfcomm_dlc *d, int err)
 		sk->sk_state_change(sk);
 	}
 
-	bh_unlock_sock(sk);
+	spin_unlock_irqrestore(&sk->sk_lock.slock, flags);
 
 	if (parent && sock_flag(sk, SOCK_ZAPPED)) {
 		/* We have to drop DLC lock here, otherwise
-- 
1.7.1.1

--
To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Bluez Devel]     [Linux Wireless Networking]     [Linux Wireless Personal Area Networking]     [Linux ATH6KL]     [Linux USB Devel]     [Linux Media Drivers]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Big List of Linux Books]

  Powered by Linux