1. 30 Apr, 2018 7 commits
    • Luc Van Oostenryck's avatar
      mwifiex: fix mwifiex_hard_start_xmit()'s return type · c126e199
      Luc Van Oostenryck authored
      The method ndo_start_xmit() is defined as returning an 'netdev_tx_t',
      which is a typedef for an enum type, but the implementation in this
      driver returns an 'int'.
      
      Fix this by returning 'netdev_tx_t' in this driver too.
      Signed-off-by: default avatarLuc Van Oostenryck <luc.vanoostenryck@gmail.com>
      Signed-off-by: default avatarKalle Valo <kvalo@codeaurora.org>
      c126e199
    • Felix Fietkau's avatar
      mt76: check for pending reset before attempting to schedule tx · 95135e8c
      Felix Fietkau authored
      The check within mt76_txq_send_burst is not enough, as it happens after
      a first frame has already been queued up
      Signed-off-by: default avatarFelix Fietkau <nbd@nbd.name>
      Signed-off-by: default avatarKalle Valo <kvalo@codeaurora.org>
      95135e8c
    • Felix Fietkau's avatar
      mt76: add rcu locking around tx scheduling · 1d868b70
      Felix Fietkau authored
      Fixes a reported lockdep error in mac80211:
      
      [  179.867321] =============================
      [  179.871510] WARNING: suspicious RCU usage
      [  179.875528] 4.14.32 #0 Not tainted
      [  179.878924] -----------------------------
      [  179.882981] backports-2017-11-01/net/mac80211/tx.c:594 suspicious rcu_dereference_check() usage!
      [  179.891785]
      [  179.891785] other info that might help us debug this:
      [  179.891785]
      [  179.899824]
      [  179.899824] rcu_scheduler_active = 2, debug_locks = 1
      [  179.906343] 2 locks held by ksoftirqd/0/7:
      [  179.910479]  #0:  (&(&q->lock)->rlock){+.-.}, at: [<86b207a4>] mt76_dma_tx_cleanup+0x64/0x354 [mt76]
      [  179.919734]  #1:  (&(&fq->lock)->rlock){+.-.}, at: [<87238410>] ieee80211_tx_dequeue+0x54/0xc3c [mac80211]
      [  179.929890]
      [  179.929890] stack backtrace:
      [  179.934257] CPU: 0 PID: 7 Comm: ksoftirqd/0 Not tainted 4.14.32 #0
      [  179.940421] Stack : 00000000 00000000 00000000 00000000 80e0fce2 00000036 00000000 00000000
      [  179.948864]         87c3d24c 80696377 8061039c 00000000 00000007 00000001 87c5db78 6534689d
      [  179.957306]         00000000 00000000 80e10000 87c5da74 00000001 0000015a 00000007 00000000
      [  179.965748]         00000000 806a0000 000e4171 00000000 00000000 00000000 ffffffff 00000001
      [  179.974189]         806c0000 8692b240 86b000d0 87316fe4 00000001 802c9a68 00000000 80700000
      [  179.982632]         ...
      [  179.985104] Call Trace:
      [  179.987582] [<80010a48>] show_stack+0x58/0x100
      [  179.992040] [<804c2c58>] dump_stack+0xe8/0x170
      [  179.996868] [<87234a04>] ieee80211_tx_h_select_key+0xa8/0x5b8 [mac80211]
      [  180.004299] [<87238d44>] ieee80211_tx_dequeue+0x988/0xc3c [mac80211]
      [  180.011048] [<86b230dc>] mt76_txq_schedule+0x110/0x3a4 [mt76]
      [  180.016821] [<86b209d0>] mt76_dma_tx_cleanup+0x290/0x354 [mt76]
      [  180.022777] [<86be2e60>] mt7603_tx_tasklet+0x40/0x6c [mt7603e]
      [  180.028637] [<80037058>] tasklet_action+0x110/0x1ec
      [  180.033532] [<804e1dac>] __do_softirq+0x164/0x35c
      [  180.038235] [<80037174>] run_ksoftirqd+0x40/0x84
      [  180.042870] [<800580c8>] smpboot_thread_fn+0x1a8/0x1d8
      [  180.048023] [<800542e8>] kthread+0x130/0x144
      [  180.052297] [<8000b1f8>] ret_from_kernel_thread+0x14/0x1c
      Signed-off-by: default avatarFelix Fietkau <nbd@nbd.name>
      Signed-off-by: default avatarKalle Valo <kvalo@codeaurora.org>
      1d868b70
    • Felix Fietkau's avatar
      mt76: add rcu locking in tid reorder function · 9febfa67
      Felix Fietkau authored
      Avoids having the tid or station entry disappear prematurely.
      Also cancel the reorder work earlier to avoid further processing delayed
      by waiting for the lock to be released
      Signed-off-by: default avatarFelix Fietkau <nbd@nbd.name>
      Signed-off-by: default avatarKalle Valo <kvalo@codeaurora.org>
      9febfa67
    • Felix Fietkau's avatar
      mt76: fix concurrent rx calls on A-MPDU release · c3d7c82a
      Felix Fietkau authored
      Add a spinlock in mt76_rx_complete. Without this, multiple stats updates
      could happen in parallel, which can lead to deadlocks. There are
      probably more corner cases fixed by this change.
      Signed-off-by: default avatarFelix Fietkau <nbd@nbd.name>
      Signed-off-by: default avatarKalle Valo <kvalo@codeaurora.org>
      c3d7c82a
    • Lorenzo Bianconi's avatar
      mt76x2: fix is_mt7612 routine · 97389373
      Lorenzo Bianconi authored
      Fix is_mt7612 routine since asic version is set in mt76_dev revision
      field and not in mt76x2_dev one.
      Moreover remove mt76x2_dev rev field since it is never used in the
      driver
      
      Fixes: 7bc04215 ('mt76: add driver code for MT76x2e')
      Signed-off-by: default avatarLorenzo Bianconi <lorenzo.bianconi@redhat.com>
      Acked-by: default avatarFelix Fietkau <nbd@nbd.name>
      Signed-off-by: default avatarKalle Valo <kvalo@codeaurora.org>
      97389373
    • Kalle Valo's avatar
      Merge tag 'iwlwifi-next-for-kalle-2018-04-26' of... · d22c763d
      Kalle Valo authored
      Merge tag 'iwlwifi-next-for-kalle-2018-04-26' of git://git.kernel.org/pub/scm/linux/kernel/git/iwlwifi/iwlwifi-next
      
      Second batch of iwlwifi patches for 4.18
      
      * Some preparations for new hardware;
      * A workaround to rescan the bus for the rare situation when older
        devices become irresponsive,
      * Hardening of the firmware loading code to avoid issues with
        corrupted files;
      * A few clean-ups and bugfixes.
      d22c763d
  2. 26 Apr, 2018 13 commits
  3. 25 Apr, 2018 8 commits
  4. 24 Apr, 2018 12 commits