Re: [PATCH] Bluetooth: Fix possible deadlock in btusb

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

 



Hi Kuba,

> commit 8f9d02f470f48416444ac3a1eacecdd0f743f1a7 introduced spinlocks
> in btusb_work. This is run in a context of a worqueue and can be interrupted
> by hardware irq. If it happens while spinlock is held, we have a deadlock.
> Solution is to use _irqsave/_resore version of locking
> 
> [  466.460560] =================================
> [  466.460565] [ INFO: inconsistent lock state ]
> [  466.460572] 4.3.0-rc6+ #1 Tainted: G        W
> [  466.460576] ---------------------------------
> [  466.460582] inconsistent {IN-HARDIRQ-W} -> {HARDIRQ-ON-W} usage.
> [  466.460589] kworker/0:2/94 [HC0[0]:SC0[0]:HE1:SE1] takes:
> [  466.460595]  (&(&data->rxlock)->rlock){?.-...}, at: [<ffffffffa0526923>] btusb_work+0xa3/0x3fd [btusb]
> [  466.460621] {IN-HARDIRQ-W} state was registered at:
> [  466.460625]   [<ffffffff811021b5>] __lock_acquire+0xc45/0x1e80
> [  466.460638]   [<ffffffff811040d5>] lock_acquire+0xe5/0x1f0
> [  466.460646]   [<ffffffff8182f108>] _raw_spin_lock+0x38/0x50
> [  466.460657]   [<ffffffffa0525448>] btusb_recv_intr+0x38/0x170 [btusb]
> [  466.460668]   [<ffffffffa0525626>] btusb_intr_complete+0xa6/0x130 [btusb]
> [  466.460679]   [<ffffffff815d8f1e>] __usb_hcd_giveback_urb+0x8e/0x160
> [  466.460690]   [<ffffffff815d911f>] usb_hcd_giveback_urb+0x3f/0x120
> [  466.460698]   [<ffffffff81606e4d>] uhci_giveback_urb+0xad/0x280
> [  466.460706]   [<ffffffff81608f64>] uhci_scan_schedule.part.33+0x6b4/0xbe0
> [  466.460714]   [<ffffffff81609b50>] uhci_irq+0xd0/0x180
> [  466.460722]   [<ffffffff815d8296>] usb_hcd_irq+0x26/0x40
> [  466.460729]   [<ffffffff81117d40>] handle_irq_event_percpu+0x40/0x300
> [  466.460739]   [<ffffffff81118040>] handle_irq_event+0x40/0x60
> [  466.460746]   [<ffffffff8111af39>] handle_fasteoi_irq+0x89/0x150
> [  466.460754]   [<ffffffff8101e0f3>] handle_irq+0x73/0x120
> [  466.460763]   [<ffffffff81832f11>] do_IRQ+0x61/0x120
> [  466.460772]   [<ffffffff8183084c>] ret_from_intr+0x0/0x31
> [  466.460780]   [<ffffffff81697a77>] cpuidle_enter+0x17/0x20
> [  466.460790]   [<ffffffff810f62c2>] call_cpuidle+0x32/0x60
> [  466.460800]   [<ffffffff810f65a8>] cpu_startup_entry+0x2b8/0x3f0
> [  466.460807]   [<ffffffff818214ca>] rest_init+0x13a/0x140
> [  466.460817]   [<ffffffff81f76029>] start_kernel+0x4a3/0x4c4
> [  466.460827]   [<ffffffff81f75339>] x86_64_start_reservations+0x2a/0x2c
> [  466.460837]   [<ffffffff81f75485>] x86_64_start_kernel+0x14a/0x16d
> [  466.460846] irq event stamp: 754913
> [  466.460851] hardirqs last  enabled at (754913): [<ffffffff8182f4cc>] _raw_spin_unlock_irq+0x2c/0x40
> [  466.460861] hardirqs last disabled at (754912): [<ffffffff8182f28d>] _raw_spin_lock_irq+0x1d/0x60
> [  466.460869] softirqs last  enabled at (753024): [<ffffffff810aeaa0>] __do_softirq+0x380/0x490
> [  466.460880] softirqs last disabled at (753009): [<ffffffff810aedef>] irq_exit+0x10f/0x120
> [  466.460888]
>               other info that might help us debug this:
> [  466.460894]  Possible unsafe locking scenario:
> 
> [  466.460899]        CPU0
> [  466.460903]        ----
> [  466.460907]   lock(&(&data->rxlock)->rlock);
> [  466.460915]   <Interrupt>
> [  466.460918]     lock(&(&data->rxlock)->rlock);
> [  466.460926]
>                *** DEADLOCK ***
> 
> [  466.460935] 2 locks held by kworker/0:2/94:
> [  466.460939]  #0:  ("events"){.+.+.+}, at: [<ffffffff810c69bb>] process_one_work+0x16b/0x660
> [  466.460958]  #1:  ((&data->work)){+.+...}, at: [<ffffffff810c69bb>] process_one_work+0x16b/0x660
> [  466.460974]
> ---
> drivers/bluetooth/btusb.c | 6 ++++--
> 1 file changed, 4 insertions(+), 2 deletions(-)

patch has been applied to bluetooth-next tree.

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