diff options
author | Larry Finger <Larry.Finger@lwfinger.net> | 2014-09-26 17:40:25 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2014-09-30 13:17:15 -0400 |
commit | 5c99f04fec93068147a3e95b439b345f203ac5b9 (patch) | |
tree | d0dd2086ff7f0ca5588d5fedec2f9b3a6f03ef4a /drivers/net/wireless/rtlwifi/rtl8821ae/hw.c | |
parent | 0529c6b8176135bcae1ab66bed6c1288456fbdec (diff) |
rtlwifi: rtl8723be: Update driver to match Realtek release of 06/28/14
This patch updates the driver to match the latest Realtek release, and
it is an important step in getting the internal code source at Realtek to match
the code in the kernel. The primary reason for this is to make it easier for
Realtek to maintain the kernel source without requiring an intermediate like me.
In this process of merging the two source repositories, there are a lot
of changes in both, and this commit is rather large.
Signed-off-by: Larry Finger <Larry.Finger@lwfinger.net>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/rtlwifi/rtl8821ae/hw.c')
-rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8821ae/hw.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/net/wireless/rtlwifi/rtl8821ae/hw.c b/drivers/net/wireless/rtlwifi/rtl8821ae/hw.c index 58bbaf432b0e..310d3163dc5b 100644 --- a/drivers/net/wireless/rtlwifi/rtl8821ae/hw.c +++ b/drivers/net/wireless/rtlwifi/rtl8821ae/hw.c | |||
@@ -48,7 +48,9 @@ static void _rtl8821ae_return_beacon_queue_skb(struct ieee80211_hw *hw) | |||
48 | struct rtl_priv *rtlpriv = rtl_priv(hw); | 48 | struct rtl_priv *rtlpriv = rtl_priv(hw); |
49 | struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw)); | 49 | struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw)); |
50 | struct rtl8192_tx_ring *ring = &rtlpci->tx_ring[BEACON_QUEUE]; | 50 | struct rtl8192_tx_ring *ring = &rtlpci->tx_ring[BEACON_QUEUE]; |
51 | unsigned long flags; | ||
51 | 52 | ||
53 | spin_lock_irqsave(&rtlpriv->locks.irq_th_lock, flags); | ||
52 | while (skb_queue_len(&ring->queue)) { | 54 | while (skb_queue_len(&ring->queue)) { |
53 | struct rtl_tx_desc *entry = &ring->desc[ring->idx]; | 55 | struct rtl_tx_desc *entry = &ring->desc[ring->idx]; |
54 | struct sk_buff *skb = __skb_dequeue(&ring->queue); | 56 | struct sk_buff *skb = __skb_dequeue(&ring->queue); |
@@ -60,6 +62,7 @@ static void _rtl8821ae_return_beacon_queue_skb(struct ieee80211_hw *hw) | |||
60 | kfree_skb(skb); | 62 | kfree_skb(skb); |
61 | ring->idx = (ring->idx + 1) % ring->entries; | 63 | ring->idx = (ring->idx + 1) % ring->entries; |
62 | } | 64 | } |
65 | spin_unlock_irqrestore(&rtlpriv->locks.irq_th_lock, flags); | ||
63 | } | 66 | } |
64 | 67 | ||
65 | static void _rtl8821ae_set_bcn_ctrl_reg(struct ieee80211_hw *hw, | 68 | static void _rtl8821ae_set_bcn_ctrl_reg(struct ieee80211_hw *hw, |