From: Tsang-Shian Lin Date: Sat, 9 Dec 2017 17:37:10 +0000 (-0600) Subject: rtlwifi: rtl_pci: Fix the bug when inactiveps is enabled. X-Git-Tag: v4.16-rc1~123^2~329^2~3 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=b7573a0a27bfa8270dea9b145448f6884b7cacc1;p=thirdparty%2Fkernel%2Flinux.git rtlwifi: rtl_pci: Fix the bug when inactiveps is enabled. Reset the driver current tx read/write index to zero when inactiveps nic out of sync with HW state. Wrong driver tx read/write index will cause Tx fail. Signed-off-by: Tsang-Shian Lin Signed-off-by: Ping-Ke Shih Signed-off-by: Larry Finger Cc: Yan-Hsuan Chuang Cc: Birming Chiu Cc: Shaofu Cc: Steven Ting Signed-off-by: Kalle Valo --- diff --git a/drivers/net/wireless/realtek/rtlwifi/pci.c b/drivers/net/wireless/realtek/rtlwifi/pci.c index 8ae36a263426d..4013394fac330 100644 --- a/drivers/net/wireless/realtek/rtlwifi/pci.c +++ b/drivers/net/wireless/realtek/rtlwifi/pci.c @@ -1555,7 +1555,14 @@ int rtl_pci_reset_trx_ring(struct ieee80211_hw *hw) dev_kfree_skb_irq(skb); ring->idx = (ring->idx + 1) % ring->entries; } + + if (rtlpriv->use_new_trx_flow) { + rtlpci->tx_ring[i].cur_tx_rp = 0; + rtlpci->tx_ring[i].cur_tx_wp = 0; + } + ring->idx = 0; + ring->entries = rtlpci->txringcount[i]; } } spin_unlock_irqrestore(&rtlpriv->locks.irq_th_lock, flags);