Patch "wifi: mt76: fix lock dependency problem for wed_lock" has been added to the 6.5-stable tree

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

 



This is a note to let you know that I've just added the patch titled

    wifi: mt76: fix lock dependency problem for wed_lock

to the 6.5-stable tree which can be found at:
    http://www.kernel.org/git/?p=linux/kernel/git/stable/stable-queue.git;a=summary

The filename of the patch is:
     wifi-mt76-fix-lock-dependency-problem-for-wed_lock.patch
and it can be found in the queue-6.5 subdirectory.

If you, or anyone else, feels it should not be added to the stable tree,
please let <stable@xxxxxxxxxxxxxxx> know about it.



commit 1adf727722140647de6d1ad1b86061e00c7ea946
Author: Lorenzo Bianconi <lorenzo@xxxxxxxxxx>
Date:   Mon Aug 28 15:16:11 2023 +0200

    wifi: mt76: fix lock dependency problem for wed_lock
    
    [ Upstream commit 195273147e520844c1aae9fbf85cb6eb0bc0fdd7 ]
    
    Fix the following kernel depency lock holding wed_lock with BH disabled.
    
    [   40.579696] mt798x-wmac 18000000.wifi: attaching wed device 0 version 2
    [   40.604648] platform 15010000.wed: MTK WED WO Firmware Version: DEV_000000, Build Time: 20221208202138
    [   40.613972] platform 15010000.wed: MTK WED WO Chip ID 00 Region 3
    [   40.943617]
    [   40.945118] ========================================================
    [   40.951457] WARNING: possible irq lock inversion dependency detected
    [   40.957797] 5.15.127 #0 Not tainted
    [   40.961276] --------------------------------------------------------
    [   40.967614] insmod/2329 just changed the state of lock:
    [   40.972827] ffffff8004003b08 (&dev->wed_lock){+.+.}-{2:2}, at: mt76_get_rxwi+0x1c/0xac [mt76]
    [   40.981387] but this lock was taken by another, SOFTIRQ-safe lock in the past:
    [   40.988592]  (&q->lock){+.-.}-{2:2}
    [   40.988602]
    [   40.988602]
    [   40.988602] and interrupts could create inverse lock ordering between them.
    [   40.988602]
    [   41.003445]
    [   41.003445] other info that might help us debug this:
    [   41.009957]  Possible interrupt unsafe locking scenario:
    [   41.009957]
    [   41.016729]        CPU0                    CPU1
    [   41.021245]        ----                    ----
    [   41.025761]   lock(&dev->wed_lock);
    [   41.029241]                                local_irq_disable();
    [   41.035145]                                lock(&q->lock);
    [   41.040620]                                lock(&dev->wed_lock);
    [   41.046616]   <Interrupt>
    [   41.049223]     lock(&q->lock);
    [   41.052356]
    [   41.052356]  *** DEADLOCK ***
    [   41.052356]
    [   41.058260] 1 lock held by insmod/2329:
    [   41.062085]  #0: ffffff80003b9988 (&dev->mutex){....}-{3:3}, at: __driver_attach+0x88/0x190
    [   41.070442]
    [   41.070442] the shortest dependencies between 2nd lock and 1st lock:
    [   41.078257]  -> (&q->lock){+.-.}-{2:2} {
    [   41.082177]     HARDIRQ-ON-W at:
    [   41.085396]                       lock_acquire+0xfc/0x2c0
    [   41.090787]                       _raw_spin_lock_bh+0x84/0xa0
    [   41.096525]                       mt76_dma_cleanup+0x24c/0x650 [mt76]
    [   41.102977]                       mt76_dma_cleanup+0x614/0x650 [mt76]
    [   41.109428]                       mt7915_eeprom_get_power_delta+0x1168/0x2464 [mt7915e]
    [   41.117435]                       mt7915_eeprom_init+0x40/0x340 [mt7915e]
    [   41.124222]                       cleanup_module+0x94/0xb28 [mt7915e]
    [   41.130662]                       platform_probe+0x64/0xbc
    [   41.136139]                       really_probe.part.0+0x98/0x2f4
    [   41.142134]                       __driver_probe_device+0x94/0x16c
    [   41.148303]                       driver_probe_device+0x40/0x120
    [   41.154299]                       __driver_attach+0x94/0x190
    [   41.159947]                       bus_for_each_dev+0x5c/0x94
    [   41.165594]                       driver_attach+0x20/0x30
    [   41.170983]                       bus_add_driver+0x104/0x1f4
    [   41.176631]                       driver_register+0x74/0x120
    [   41.182280]                       __platform_driver_register+0x24/0x30
    [   41.188797]                       0xffffffc000cb1074
    [   41.193754]                       do_one_initcall+0x70/0x2cc
    [   41.199403]                       do_init_module+0x44/0x240
    [   41.204968]                       load_module+0x1f5c/0x2874
    [   41.210532]                       __do_sys_init_module+0x1d8/0x2ac
    [   41.216702]                       __arm64_sys_init_module+0x18/0x20
    [   41.222958]                       invoke_syscall.constprop.0+0x4c/0xe0
    [   41.229474]                       do_el0_svc+0x50/0xf0
    [   41.234602]                       el0_svc+0x4c/0xcc
    [   41.239471]                       el0t_64_sync_handler+0xe0/0x110
    [   41.245556]                       el0t_64_sync+0x15c/0x160
    [   41.251029]     IN-SOFTIRQ-W at:
    [   41.254249]                       lock_acquire+0xfc/0x2c0
    [   41.259638]                       _raw_spin_lock_bh+0x84/0xa0
    [   41.265372]                       mt76_queue_tx_complete+0x34/0x70 [mt76]
    [   41.272170]                       mt76_free_pending_rxwi+0x36c/0x5d0 [mt76]
    [   41.279140]                       mt76_free_pending_rxwi+0x5c0/0x5d0 [mt76]
    [   41.286111]                       mt7915_eeprom_get_power_delta+0x620/0x2464 [mt7915e]
    [   41.294026]                       __napi_poll.constprop.0+0x5c/0x230
    [   41.300372]                       net_rx_action+0xe4/0x294
    [   41.305847]                       _stext+0x154/0x4cc
    [   41.310801]                       do_softirq+0xa4/0xbc
    [   41.315930]                       __local_bh_enable_ip+0x168/0x174
    [   41.322097]                       napi_threaded_poll+0xbc/0x140
    [   41.328007]                       kthread+0x13c/0x150
    [   41.333049]                       ret_from_fork+0x10/0x20
    [   41.338437]     INITIAL USE at:
    [   41.341568]                      lock_acquire+0xfc/0x2c0
    [   41.346869]                      _raw_spin_lock_bh+0x84/0xa0
    [   41.352519]                      mt76_dma_cleanup+0x24c/0x650 [mt76]
    [   41.358882]                      mt76_dma_cleanup+0x614/0x650 [mt76]
    [   41.365245]                      mt7915_eeprom_get_power_delta+0x1168/0x2464 [mt7915e]
    [   41.373160]                      mt7915_eeprom_init+0x40/0x340 [mt7915e]
    [   41.379860]                      cleanup_module+0x94/0xb28 [mt7915e]
    [   41.386213]                      platform_probe+0x64/0xbc
    [   41.391602]                      really_probe.part.0+0x98/0x2f4
    [   41.397511]                      __driver_probe_device+0x94/0x16c
    [   41.403594]                      driver_probe_device+0x40/0x120
    [   41.409502]                      __driver_attach+0x94/0x190
    [   41.415063]                      bus_for_each_dev+0x5c/0x94
    [   41.420625]                      driver_attach+0x20/0x30
    [   41.425926]                      bus_add_driver+0x104/0x1f4
    [   41.431487]                      driver_register+0x74/0x120
    [   41.437049]                      __platform_driver_register+0x24/0x30
    [   41.443479]                      0xffffffc000cb1074
    [   41.448346]                      do_one_initcall+0x70/0x2cc
    [   41.453907]                      do_init_module+0x44/0x240
    [   41.459383]                      load_module+0x1f5c/0x2874
    [   41.464860]                      __do_sys_init_module+0x1d8/0x2ac
    [   41.470944]                      __arm64_sys_init_module+0x18/0x20
    [   41.477113]                      invoke_syscall.constprop.0+0x4c/0xe0
    [   41.483542]                      do_el0_svc+0x50/0xf0
    [   41.488582]                      el0_svc+0x4c/0xcc
    [   41.493364]                      el0t_64_sync_handler+0xe0/0x110
    [   41.499361]                      el0t_64_sync+0x15c/0x160
    [   41.504748]   }
    [   41.506489]   ... key      at: [<ffffffc000c65ba0>] __this_module+0x3e0/0xffffffffffffa840 [mt76]
    [   41.515371]   ... acquired at:
    [   41.518413]    _raw_spin_lock+0x60/0x74
    [   41.522240]    mt76_get_rxwi+0x1c/0xac [mt76]
    [   41.526608]    mt76_dma_cleanup+0x3e0/0x650 [mt76]
    [   41.531410]    mt76_dma_cleanup+0x614/0x650 [mt76]
    [   41.536211]    mt7915_dma_init+0x408/0x7b0 [mt7915e]
    [   41.541177]    mt7915_register_device+0x310/0x620 [mt7915e]
    [   41.546749]    mt7915_mmio_probe+0xcec/0x1d44 [mt7915e]
    [   41.551973]    platform_probe+0x64/0xbc
    [   41.555802]    really_probe.part.0+0x98/0x2f4
    [   41.560149]    __driver_probe_device+0x94/0x16c
    [   41.564670]    driver_probe_device+0x40/0x120
    [   41.569017]    __driver_attach+0x94/0x190
    [   41.573019]    bus_for_each_dev+0x5c/0x94
    [   41.577018]    driver_attach+0x20/0x30
    [   41.580758]    bus_add_driver+0x104/0x1f4
    [   41.584758]    driver_register+0x74/0x120
    [   41.588759]    __platform_driver_register+0x24/0x30
    [   41.593628]    init_module+0x74/0x1000 [mt7915e]
    [   41.598248]    do_one_initcall+0x70/0x2cc
    [   41.602248]    do_init_module+0x44/0x240
    [   41.606162]    load_module+0x1f5c/0x2874
    [   41.610078]    __do_sys_init_module+0x1d8/0x2ac
    [   41.614600]    __arm64_sys_init_module+0x18/0x20
    [   41.619209]    invoke_syscall.constprop.0+0x4c/0xe0
    [   41.624076]    do_el0_svc+0x50/0xf0
    [   41.627555]    el0_svc+0x4c/0xcc
    [   41.630776]    el0t_64_sync_handler+0xe0/0x110
    [   41.635211]    el0t_64_sync+0x15c/0x160
    [   41.639037]
    [   41.640517] -> (&dev->wed_lock){+.+.}-{2:2} {
    [   41.644872]    HARDIRQ-ON-W at:
    [   41.648003]                     lock_acquire+0xfc/0x2c0
    [   41.653219]                     _raw_spin_lock+0x60/0x74
    [   41.658520]                     mt76_free_pending_rxwi+0xc0/0x5d0 [mt76]
    [   41.665232]                     mt76_dma_cleanup+0x1dc/0x650 [mt76]
    [   41.671508]                     mt7915_eeprom_get_power_delta+0x1830/0x2464 [mt7915e]
    [   41.679336]                     mt7915_unregister_device+0x5b4/0x910 [mt7915e]
    [   41.686555]                     mt7915_eeprom_get_target_power+0xb8/0x230 [mt7915e]
    [   41.694209]                     mt7986_wmac_enable+0xc30/0xcd0 [mt7915e]
    [   41.700909]                     platform_remove+0x4c/0x64
    [   41.706298]                     __device_release_driver+0x194/0x240
    [   41.712554]                     driver_detach+0xc0/0x100
    [   41.717857]                     bus_remove_driver+0x54/0xac
    [   41.723418]                     driver_unregister+0x2c/0x54
    [   41.728980]                     platform_driver_unregister+0x10/0x20
    [   41.735323]                     mt7915_ops+0x244/0xffffffffffffed58 [mt7915e]
    [   41.742457]                     __arm64_sys_delete_module+0x170/0x23c
    [   41.748887]                     invoke_syscall.constprop.0+0x4c/0xe0
    [   41.755229]                     do_el0_svc+0x50/0xf0
    [   41.760183]                     el0_svc+0x4c/0xcc
    [   41.764878]                     el0t_64_sync_handler+0xe0/0x110
    [   41.770788]                     el0t_64_sync+0x15c/0x160
    [   41.776088]    SOFTIRQ-ON-W at:
    [   41.779220]                     lock_acquire+0xfc/0x2c0
    [   41.784435]                     _raw_spin_lock+0x60/0x74
    [   41.789737]                     mt76_get_rxwi+0x1c/0xac [mt76]
    [   41.795580]                     mt7915_debugfs_rx_log+0x804/0xb74 [mt7915e]
    [   41.802540]                     mtk_wed_start+0x970/0xaa0
    [   41.807929]                     mt7915_dma_start+0x26c/0x630 [mt7915e]
    [   41.814455]                     mt7915_dma_start+0x5a4/0x630 [mt7915e]
    [   41.820981]                     mt7915_dma_init+0x45c/0x7b0 [mt7915e]
    [   41.827420]                     mt7915_register_device+0x310/0x620 [mt7915e]
    [   41.834467]                     mt7915_mmio_probe+0xcec/0x1d44 [mt7915e]
    [   41.841167]                     platform_probe+0x64/0xbc
    [   41.846469]                     really_probe.part.0+0x98/0x2f4
    [   41.852291]                     __driver_probe_device+0x94/0x16c
    [   41.858286]                     driver_probe_device+0x40/0x120
    [   41.864107]                     __driver_attach+0x94/0x190
    [   41.869582]                     bus_for_each_dev+0x5c/0x94
    [   41.875056]                     driver_attach+0x20/0x30
    [   41.880270]                     bus_add_driver+0x104/0x1f4
    [   41.885745]                     driver_register+0x74/0x120
    [   41.891221]                     __platform_driver_register+0x24/0x30
    [   41.897564]                     init_module+0x74/0x1000 [mt7915e]
    [   41.903657]                     do_one_initcall+0x70/0x2cc
    [   41.909130]                     do_init_module+0x44/0x240
    [   41.914520]                     load_module+0x1f5c/0x2874
    [   41.919909]                     __do_sys_init_module+0x1d8/0x2ac
    [   41.925905]                     __arm64_sys_init_module+0x18/0x20
    [   41.931989]                     invoke_syscall.constprop.0+0x4c/0xe0
    [   41.938331]                     do_el0_svc+0x50/0xf0
    [   41.943285]                     el0_svc+0x4c/0xcc
    [   41.947981]                     el0t_64_sync_handler+0xe0/0x110
    [   41.953892]                     el0t_64_sync+0x15c/0x160
    [   41.959192]    INITIAL USE at:
    [   41.962238]                    lock_acquire+0xfc/0x2c0
    [   41.967365]                    _raw_spin_lock+0x60/0x74
    [   41.972580]                    mt76_free_pending_rxwi+0xc0/0x5d0 [mt76]
    [   41.979206]                    mt76_dma_cleanup+0x1dc/0x650 [mt76]
    [   41.985395]                    mt7915_eeprom_get_power_delta+0x1830/0x2464 [mt7915e]
    [   41.993137]                    mt7915_unregister_device+0x5b4/0x910 [mt7915e]
    [   42.000270]                    mt7915_eeprom_get_target_power+0xb8/0x230 [mt7915e]
    [   42.007837]                    mt7986_wmac_enable+0xc30/0xcd0 [mt7915e]
    [   42.014450]                    platform_remove+0x4c/0x64
    [   42.019753]                    __device_release_driver+0x194/0x240
    [   42.025922]                    driver_detach+0xc0/0x100
    [   42.031137]                    bus_remove_driver+0x54/0xac
    [   42.036612]                    driver_unregister+0x2c/0x54
    [   42.042087]                    platform_driver_unregister+0x10/0x20
    [   42.048344]                    mt7915_ops+0x244/0xffffffffffffed58 [mt7915e]
    [   42.055391]                    __arm64_sys_delete_module+0x170/0x23c
    [   42.061735]                    invoke_syscall.constprop.0+0x4c/0xe0
    [   42.067990]                    do_el0_svc+0x50/0xf0
    [   42.072857]                    el0_svc+0x4c/0xcc
    [   42.077466]                    el0t_64_sync_handler+0xe0/0x110
    [   42.083289]                    el0t_64_sync+0x15c/0x160
    [   42.088503]  }
    [   42.090157]  ... key      at: [<ffffffc000c65c10>] __this_module+0x450/0xffffffffffffa840 [mt76]
    [   42.098951]  ... acquired at:
    [   42.101907]    __lock_acquire+0x718/0x1df0
    [   42.105994]    lock_acquire+0xfc/0x2c0
    [   42.109734]    _raw_spin_lock+0x60/0x74
    [   42.113561]    mt76_get_rxwi+0x1c/0xac [mt76]
    [   42.117929]    mt7915_debugfs_rx_log+0x804/0xb74 [mt7915e]
    [   42.123415]    mtk_wed_start+0x970/0xaa0
    [   42.127328]    mt7915_dma_start+0x26c/0x630 [mt7915e]
    [   42.132379]    mt7915_dma_start+0x5a4/0x630 [mt7915e]
    [   42.137430]    mt7915_dma_init+0x45c/0x7b0 [mt7915e]
    [   42.142395]    mt7915_register_device+0x310/0x620 [mt7915e]
    [   42.147967]    mt7915_mmio_probe+0xcec/0x1d44 [mt7915e]
    [   42.153192]    platform_probe+0x64/0xbc
    [   42.157019]    really_probe.part.0+0x98/0x2f4
    [   42.161367]    __driver_probe_device+0x94/0x16c
    [   42.165887]    driver_probe_device+0x40/0x120
    [   42.170234]    __driver_attach+0x94/0x190
    [   42.174235]    bus_for_each_dev+0x5c/0x94
    [   42.178235]    driver_attach+0x20/0x30
    [   42.181974]    bus_add_driver+0x104/0x1f4
    [   42.185974]    driver_register+0x74/0x120
    [   42.189974]    __platform_driver_register+0x24/0x30
    [   42.194842]    init_module+0x74/0x1000 [mt7915e]
    [   42.199460]    do_one_initcall+0x70/0x2cc
    [   42.203460]    do_init_module+0x44/0x240
    [   42.207376]    load_module+0x1f5c/0x2874
    [   42.211290]    __do_sys_init_module+0x1d8/0x2ac
    [   42.215813]    __arm64_sys_init_module+0x18/0x20
    [   42.220421]    invoke_syscall.constprop.0+0x4c/0xe0
    [   42.225288]    do_el0_svc+0x50/0xf0
    [   42.228768]    el0_svc+0x4c/0xcc
    [   42.231989]    el0t_64_sync_handler+0xe0/0x110
    [   42.236424]    el0t_64_sync+0x15c/0x160
    [   42.240249]
    [   42.241730]
    [   42.241730] stack backtrace:
    [   42.246074] CPU: 1 PID: 2329 Comm: insmod Not tainted 5.15.127 #0
    [   42.252157] Hardware name: GainStrong Oolite-MT7981B V1 Dev Board (NAND boot) (DT)
    [   42.259712] Call trace:
    [   42.262147]  dump_backtrace+0x0/0x174
    [   42.265802]  show_stack+0x14/0x20
    [   42.269108]  dump_stack_lvl+0x84/0xac
    [   42.272761]  dump_stack+0x14/0x2c
    [   42.276066]  print_irq_inversion_bug.part.0+0x1b0/0x1c4
    [   42.281285]  mark_lock+0x8b8/0x8bc
    [   42.284678]  __lock_acquire+0x718/0x1df0
    [   42.288592]  lock_acquire+0xfc/0x2c0
    [   42.292158]  _raw_spin_lock+0x60/0x74
    [   42.295811]  mt76_get_rxwi+0x1c/0xac [mt76]
    [   42.300008]  mt7915_debugfs_rx_log+0x804/0xb74 [mt7915e]
    [   42.305320]  mtk_wed_start+0x970/0xaa0
    [   42.309059]  mt7915_dma_start+0x26c/0x630 [mt7915e]
    [   42.313937]  mt7915_dma_start+0x5a4/0x630 [mt7915e]
    [   42.318815]  mt7915_dma_init+0x45c/0x7b0 [mt7915e]
    [   42.323606]  mt7915_register_device+0x310/0x620 [mt7915e]
    [   42.329005]  mt7915_mmio_probe+0xcec/0x1d44 [mt7915e]
    [   42.334056]  platform_probe+0x64/0xbc
    [   42.337711]  really_probe.part.0+0x98/0x2f4
    [   42.341885]  __driver_probe_device+0x94/0x16c
    [   42.346232]  driver_probe_device+0x40/0x120
    [   42.350407]  __driver_attach+0x94/0x190
    [   42.354234]  bus_for_each_dev+0x5c/0x94
    [   42.358061]  driver_attach+0x20/0x30
    [   42.361627]  bus_add_driver+0x104/0x1f4
    [   42.365454]  driver_register+0x74/0x120
    [   42.369282]  __platform_driver_register+0x24/0x30
    [   42.373977]  init_module+0x74/0x1000 [mt7915e]
    [   42.378423]  do_one_initcall+0x70/0x2cc
    [   42.382249]  do_init_module+0x44/0x240
    [   42.385990]  load_module+0x1f5c/0x2874
    [   42.389733]  __do_sys_init_module+0x1d8/0x2ac
    [   42.394082]  __arm64_sys_init_module+0x18/0x20
    [   42.398518]  invoke_syscall.constprop.0+0x4c/0xe0
    [   42.403211]  do_el0_svc+0x50/0xf0
    [   42.406517]  el0_svc+0x4c/0xcc
    [   42.409565]  el0t_64_sync_handler+0xe0/0x110
    [   42.413827]  el0t_64_sync+0x15c/0x160
    [   42.674858] mt798x-wmac 18000000.wifi: HW/SW Version: 0x8a108a10, Build Time: 20221208201745a
    [   42.674858]
    [   42.692078] mt798x-wmac 18000000.wifi: WM Firmware Version: ____000000, Build Time: 20221208201806
    [   42.735606] mt798x-wmac 18000000.wifi: WA Firmware Version: DEV_000000, Build Time: 20221208202048
    
    Tested-by: Daniel Golle <daniel@xxxxxxxxxxxxxx>
    Fixes: 2666bece0905 ("wifi: mt76: introduce rxwi and rx token utility routines")
    Signed-off-by: Lorenzo Bianconi <lorenzo@xxxxxxxxxx>
    Acked-by: Felix Fietkau <nbd@xxxxxxxx>
    Signed-off-by: Kalle Valo <kvalo@xxxxxxxxxx>
    Link: https://lore.kernel.org/r/ee80be41c2a8d8749d83c6950a272a5e77aadd45.1693228333.git.lorenzo@xxxxxxxxxx
    Signed-off-by: Sasha Levin <sashal@xxxxxxxxxx>

diff --git a/drivers/net/wireless/mediatek/mt76/dma.c b/drivers/net/wireless/mediatek/mt76/dma.c
index 465190ebaf1c4..f539913aadf86 100644
--- a/drivers/net/wireless/mediatek/mt76/dma.c
+++ b/drivers/net/wireless/mediatek/mt76/dma.c
@@ -93,13 +93,13 @@ __mt76_get_rxwi(struct mt76_dev *dev)
 {
 	struct mt76_txwi_cache *t = NULL;
 
-	spin_lock(&dev->wed_lock);
+	spin_lock_bh(&dev->wed_lock);
 	if (!list_empty(&dev->rxwi_cache)) {
 		t = list_first_entry(&dev->rxwi_cache, struct mt76_txwi_cache,
 				     list);
 		list_del(&t->list);
 	}
-	spin_unlock(&dev->wed_lock);
+	spin_unlock_bh(&dev->wed_lock);
 
 	return t;
 }
@@ -145,9 +145,9 @@ mt76_put_rxwi(struct mt76_dev *dev, struct mt76_txwi_cache *t)
 	if (!t)
 		return;
 
-	spin_lock(&dev->wed_lock);
+	spin_lock_bh(&dev->wed_lock);
 	list_add(&t->list, &dev->rxwi_cache);
-	spin_unlock(&dev->wed_lock);
+	spin_unlock_bh(&dev->wed_lock);
 }
 EXPORT_SYMBOL_GPL(mt76_put_rxwi);
 



[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux