Re: [PATCH] Bluetooth: Fix inconsistent lock state with RFCOMM

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

 



Hi Gustavo,

> 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

I am missing an explanation why you fixed it this way. And also why thi
sis the right way to fix it. Directly referencing sk->sk_lock seems
pretty much wrong to me.

Regards

Marcel


--
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