提交 4b0dd98e 编写于 作者: J Johannes Berg 提交者: John W. Linville

mac80211: clean up rx handling wrt. found_sta

If a station was found, then we'll have exited
the function already, so it is not necessary to
have a variable keeping track of it.
Signed-off-by: NJohannes Berg <johannes.berg@intel.com>
Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
上级 4406c376
...@@ -2651,7 +2651,6 @@ static void __ieee80211_rx_handle_packet(struct ieee80211_hw *hw, ...@@ -2651,7 +2651,6 @@ static void __ieee80211_rx_handle_packet(struct ieee80211_hw *hw,
struct ieee80211_rx_data rx; struct ieee80211_rx_data rx;
struct ieee80211_sub_if_data *prev; struct ieee80211_sub_if_data *prev;
struct sta_info *sta, *tmp, *prev_sta; struct sta_info *sta, *tmp, *prev_sta;
bool found_sta = false;
int err = 0; int err = 0;
fc = ((struct ieee80211_hdr *)skb->data)->frame_control; fc = ((struct ieee80211_hdr *)skb->data)->frame_control;
...@@ -2684,8 +2683,6 @@ static void __ieee80211_rx_handle_packet(struct ieee80211_hw *hw, ...@@ -2684,8 +2683,6 @@ static void __ieee80211_rx_handle_packet(struct ieee80211_hw *hw,
prev_sta = NULL; prev_sta = NULL;
for_each_sta_info(local, hdr->addr2, sta, tmp) { for_each_sta_info(local, hdr->addr2, sta, tmp) {
found_sta = true;
if (!prev_sta) { if (!prev_sta) {
prev_sta = sta; prev_sta = sta;
continue; continue;
...@@ -2707,43 +2704,40 @@ static void __ieee80211_rx_handle_packet(struct ieee80211_hw *hw, ...@@ -2707,43 +2704,40 @@ static void __ieee80211_rx_handle_packet(struct ieee80211_hw *hw,
} }
} }
if (!found_sta) { prev = NULL;
prev = NULL;
list_for_each_entry_rcu(sdata, &local->interfaces, list) {
if (!ieee80211_sdata_running(sdata))
continue;
if (sdata->vif.type == NL80211_IFTYPE_MONITOR ||
sdata->vif.type == NL80211_IFTYPE_AP_VLAN)
continue;
/* list_for_each_entry_rcu(sdata, &local->interfaces, list) {
* frame is destined for this interface, but if it's if (!ieee80211_sdata_running(sdata))
* not also for the previous one we handle that after continue;
* the loop to avoid copying the SKB once too much
*/
if (!prev) { if (sdata->vif.type == NL80211_IFTYPE_MONITOR ||
prev = sdata; sdata->vif.type == NL80211_IFTYPE_AP_VLAN)
continue; continue;
}
rx.sta = sta_info_get_bss(prev, hdr->addr2); /*
rx.sdata = prev; * frame is destined for this interface, but if it's
ieee80211_prepare_and_rx_handle(&rx, skb, false); * not also for the previous one we handle that after
* the loop to avoid copying the SKB once too much
*/
if (!prev) {
prev = sdata; prev = sdata;
continue;
} }
if (prev) { rx.sta = sta_info_get_bss(prev, hdr->addr2);
rx.sta = sta_info_get_bss(prev, hdr->addr2); rx.sdata = prev;
rx.sdata = prev; ieee80211_prepare_and_rx_handle(&rx, skb, false);
if (ieee80211_prepare_and_rx_handle(&rx, skb, true)) prev = sdata;
return; }
}
if (prev) {
rx.sta = sta_info_get_bss(prev, hdr->addr2);
rx.sdata = prev;
if (ieee80211_prepare_and_rx_handle(&rx, skb, true))
return;
} }
dev_kfree_skb(skb); dev_kfree_skb(skb);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册