提交 90908e1c 编写于 作者: J Julia Lawall 提交者: John W. Linville

rtlwifi: use ether_addr_equal_64bits

Ether_addr_equal_64bits is more efficient than ether_addr_equal, and can be
used when each argument is an array within a structure that contains at
least two bytes of data beyond the array.

The structures involved are:
ieee80211_hdr defined in include/linux/ieee80211.h and
rtl_mac defined in drivers/net/wireless/rtlwifi/wifi.h

This was done using Coccinelle (http://coccinelle.lip6.fr/).
Signed-off-by: NJulia Lawall <Julia.Lawall@lip6.fr>
Acked-by: NLarry Finger <Larry.Finger@lwfinger.net>
Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
上级 3f9a79b5
...@@ -1293,7 +1293,7 @@ void rtl_beacon_statistic(struct ieee80211_hw *hw, struct sk_buff *skb) ...@@ -1293,7 +1293,7 @@ void rtl_beacon_statistic(struct ieee80211_hw *hw, struct sk_buff *skb)
return; return;
/* and only beacons from the associated BSSID, please */ /* and only beacons from the associated BSSID, please */
if (!ether_addr_equal(hdr->addr3, rtlpriv->mac80211.bssid)) if (!ether_addr_equal_64bits(hdr->addr3, rtlpriv->mac80211.bssid))
return; return;
rtlpriv->link_info.bcn_rx_inperiod++; rtlpriv->link_info.bcn_rx_inperiod++;
...@@ -1781,7 +1781,7 @@ void rtl_recognize_peer(struct ieee80211_hw *hw, u8 *data, unsigned int len) ...@@ -1781,7 +1781,7 @@ void rtl_recognize_peer(struct ieee80211_hw *hw, u8 *data, unsigned int len)
return; return;
/* and only beacons from the associated BSSID, please */ /* and only beacons from the associated BSSID, please */
if (!ether_addr_equal(hdr->addr3, rtlpriv->mac80211.bssid)) if (!ether_addr_equal_64bits(hdr->addr3, rtlpriv->mac80211.bssid))
return; return;
if (rtl_find_221_ie(hw, data, len)) if (rtl_find_221_ie(hw, data, len))
......
...@@ -478,7 +478,7 @@ void rtl_swlps_beacon(struct ieee80211_hw *hw, void *data, unsigned int len) ...@@ -478,7 +478,7 @@ void rtl_swlps_beacon(struct ieee80211_hw *hw, void *data, unsigned int len)
return; return;
/* and only beacons from the associated BSSID, please */ /* and only beacons from the associated BSSID, please */
if (!ether_addr_equal(hdr->addr3, rtlpriv->mac80211.bssid)) if (!ether_addr_equal_64bits(hdr->addr3, rtlpriv->mac80211.bssid))
return; return;
rtlpriv->psc.last_beacon = jiffies; rtlpriv->psc.last_beacon = jiffies;
...@@ -923,7 +923,7 @@ void rtl_p2p_info(struct ieee80211_hw *hw, void *data, unsigned int len) ...@@ -923,7 +923,7 @@ void rtl_p2p_info(struct ieee80211_hw *hw, void *data, unsigned int len)
return; return;
/* and only beacons from the associated BSSID, please */ /* and only beacons from the associated BSSID, please */
if (!ether_addr_equal(hdr->addr3, rtlpriv->mac80211.bssid)) if (!ether_addr_equal_64bits(hdr->addr3, rtlpriv->mac80211.bssid))
return; return;
/* check if this really is a beacon */ /* check if this really is a beacon */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册