aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
Diffstat (limited to 'net')
-rw-r--r--net/mac80211/ieee80211.c2
-rw-r--r--net/mac80211/ieee80211_i.h13
-rw-r--r--net/mac80211/rx.c80
-rw-r--r--net/mac80211/tx.c9
4 files changed, 43 insertions, 61 deletions
diff --git a/net/mac80211/ieee80211.c b/net/mac80211/ieee80211.c
index 83694fb49734..78fd91895c80 100644
--- a/net/mac80211/ieee80211.c
+++ b/net/mac80211/ieee80211.c
@@ -1429,8 +1429,6 @@ struct ieee80211_hw *ieee80211_alloc_hw(size_t priv_data_len,
1429 local->hw.queues = 1; /* default */ 1429 local->hw.queues = 1; /* default */
1430 1430
1431 local->mdev = mdev; 1431 local->mdev = mdev;
1432 local->rx_handlers = ieee80211_rx_handlers;
1433 local->tx_handlers = ieee80211_tx_handlers;
1434 1432
1435 local->bridge_packets = 1; 1433 local->bridge_packets = 1;
1436 1434
diff --git a/net/mac80211/ieee80211_i.h b/net/mac80211/ieee80211_i.h
index 21d54b27ccc1..1129a4299de7 100644
--- a/net/mac80211/ieee80211_i.h
+++ b/net/mac80211/ieee80211_i.h
@@ -190,12 +190,6 @@ struct ieee80211_tx_stored_packet {
190 unsigned int last_frag_rate_ctrl_probe; 190 unsigned int last_frag_rate_ctrl_probe;
191}; 191};
192 192
193typedef ieee80211_tx_result (*ieee80211_tx_handler)
194(struct ieee80211_txrx_data *tx);
195
196typedef ieee80211_rx_result (*ieee80211_rx_handler)
197(struct ieee80211_txrx_data *rx);
198
199struct beacon_data { 193struct beacon_data {
200 u8 *head, *tail; 194 u8 *head, *tail;
201 int head_len, tail_len; 195 int head_len, tail_len;
@@ -477,9 +471,6 @@ struct ieee80211_local {
477 * deliver multicast frames both back to wireless 471 * deliver multicast frames both back to wireless
478 * media and to the local net stack */ 472 * media and to the local net stack */
479 473
480 ieee80211_rx_handler *rx_handlers;
481 ieee80211_tx_handler *tx_handlers;
482
483 struct list_head interfaces; 474 struct list_head interfaces;
484 475
485 bool sta_sw_scanning; 476 bool sta_sw_scanning;
@@ -779,11 +770,7 @@ int ieee80211_if_remove(struct net_device *dev, const char *name, int id);
779void ieee80211_if_free(struct net_device *dev); 770void ieee80211_if_free(struct net_device *dev);
780void ieee80211_if_sdata_init(struct ieee80211_sub_if_data *sdata); 771void ieee80211_if_sdata_init(struct ieee80211_sub_if_data *sdata);
781 772
782/* rx handling */
783extern ieee80211_rx_handler ieee80211_rx_handlers[];
784
785/* tx handling */ 773/* tx handling */
786extern ieee80211_tx_handler ieee80211_tx_handlers[];
787void ieee80211_clear_tx_pending(struct ieee80211_local *local); 774void ieee80211_clear_tx_pending(struct ieee80211_local *local);
788void ieee80211_tx_pending(unsigned long data); 775void ieee80211_tx_pending(unsigned long data);
789int ieee80211_master_start_xmit(struct sk_buff *skb, struct net_device *dev); 776int ieee80211_master_start_xmit(struct sk_buff *skb, struct net_device *dev);
diff --git a/net/mac80211/rx.c b/net/mac80211/rx.c
index 794917fccd9b..0ab9fef8ea8b 100644
--- a/net/mac80211/rx.c
+++ b/net/mac80211/rx.c
@@ -1448,42 +1448,6 @@ ieee80211_rx_h_mgmt(struct ieee80211_txrx_data *rx)
1448 return RX_QUEUED; 1448 return RX_QUEUED;
1449} 1449}
1450 1450
1451static void ieee80211_invoke_rx_handlers(struct ieee80211_local *local,
1452 ieee80211_rx_handler *handlers,
1453 struct ieee80211_txrx_data *rx,
1454 struct sta_info *sta)
1455{
1456 ieee80211_rx_handler *handler;
1457 ieee80211_rx_result res = RX_DROP_MONITOR;
1458
1459 for (handler = handlers; *handler != NULL; handler++) {
1460 res = (*handler)(rx);
1461
1462 switch (res) {
1463 case RX_CONTINUE:
1464 continue;
1465 case RX_DROP_UNUSABLE:
1466 case RX_DROP_MONITOR:
1467 I802_DEBUG_INC(local->rx_handlers_drop);
1468 if (sta)
1469 sta->rx_dropped++;
1470 break;
1471 case RX_QUEUED:
1472 I802_DEBUG_INC(local->rx_handlers_queued);
1473 break;
1474 }
1475 break;
1476 }
1477
1478 switch (res) {
1479 case RX_DROP_MONITOR:
1480 case RX_DROP_UNUSABLE:
1481 case RX_CONTINUE:
1482 dev_kfree_skb(rx->skb);
1483 break;
1484 }
1485}
1486
1487static void ieee80211_rx_michael_mic_report(struct net_device *dev, 1451static void ieee80211_rx_michael_mic_report(struct net_device *dev,
1488 struct ieee80211_hdr *hdr, 1452 struct ieee80211_hdr *hdr,
1489 struct sta_info *sta, 1453 struct sta_info *sta,
@@ -1557,7 +1521,8 @@ static void ieee80211_rx_michael_mic_report(struct net_device *dev,
1557 rx->skb = NULL; 1521 rx->skb = NULL;
1558} 1522}
1559 1523
1560ieee80211_rx_handler ieee80211_rx_handlers[] = 1524typedef ieee80211_rx_result (*ieee80211_rx_handler)(struct ieee80211_txrx_data *);
1525static ieee80211_rx_handler ieee80211_rx_handlers[] =
1561{ 1526{
1562 ieee80211_rx_h_if_stats, 1527 ieee80211_rx_h_if_stats,
1563 ieee80211_rx_h_passive_scan, 1528 ieee80211_rx_h_passive_scan,
@@ -1579,6 +1544,41 @@ ieee80211_rx_handler ieee80211_rx_handlers[] =
1579 NULL 1544 NULL
1580}; 1545};
1581 1546
1547static void ieee80211_invoke_rx_handlers(struct ieee80211_local *local,
1548 struct ieee80211_txrx_data *rx,
1549 struct sta_info *sta)
1550{
1551 ieee80211_rx_handler *handler;
1552 ieee80211_rx_result res = RX_DROP_MONITOR;
1553
1554 for (handler = ieee80211_rx_handlers; *handler != NULL; handler++) {
1555 res = (*handler)(rx);
1556
1557 switch (res) {
1558 case RX_CONTINUE:
1559 continue;
1560 case RX_DROP_UNUSABLE:
1561 case RX_DROP_MONITOR:
1562 I802_DEBUG_INC(local->rx_handlers_drop);
1563 if (sta)
1564 sta->rx_dropped++;
1565 break;
1566 case RX_QUEUED:
1567 I802_DEBUG_INC(local->rx_handlers_queued);
1568 break;
1569 }
1570 break;
1571 }
1572
1573 switch (res) {
1574 case RX_DROP_MONITOR:
1575 case RX_DROP_UNUSABLE:
1576 case RX_CONTINUE:
1577 dev_kfree_skb(rx->skb);
1578 break;
1579 }
1580}
1581
1582/* main receive path */ 1582/* main receive path */
1583 1583
1584static int prepare_for_handlers(struct ieee80211_sub_if_data *sdata, 1584static int prepare_for_handlers(struct ieee80211_sub_if_data *sdata,
@@ -1756,8 +1756,7 @@ static void __ieee80211_rx_handle_packet(struct ieee80211_hw *hw,
1756 rx.skb = skb_new; 1756 rx.skb = skb_new;
1757 rx.dev = prev->dev; 1757 rx.dev = prev->dev;
1758 rx.sdata = prev; 1758 rx.sdata = prev;
1759 ieee80211_invoke_rx_handlers(local, local->rx_handlers, 1759 ieee80211_invoke_rx_handlers(local, &rx, sta);
1760 &rx, sta);
1761 prev = sdata; 1760 prev = sdata;
1762 } 1761 }
1763 if (prev) { 1762 if (prev) {
@@ -1765,8 +1764,7 @@ static void __ieee80211_rx_handle_packet(struct ieee80211_hw *hw,
1765 rx.skb = skb; 1764 rx.skb = skb;
1766 rx.dev = prev->dev; 1765 rx.dev = prev->dev;
1767 rx.sdata = prev; 1766 rx.sdata = prev;
1768 ieee80211_invoke_rx_handlers(local, local->rx_handlers, 1767 ieee80211_invoke_rx_handlers(local, &rx, sta);
1769 &rx, sta);
1770 } else 1768 } else
1771 dev_kfree_skb(skb); 1769 dev_kfree_skb(skb);
1772 1770
diff --git a/net/mac80211/tx.c b/net/mac80211/tx.c
index 0cba4a214876..181d97015f61 100644
--- a/net/mac80211/tx.c
+++ b/net/mac80211/tx.c
@@ -813,10 +813,9 @@ ieee80211_tx_h_load_stats(struct ieee80211_txrx_data *tx)
813 return TX_CONTINUE; 813 return TX_CONTINUE;
814} 814}
815 815
816/* TODO: implement register/unregister functions for adding TX/RX handlers
817 * into ordered list */
818 816
819ieee80211_tx_handler ieee80211_tx_handlers[] = 817typedef ieee80211_tx_result (*ieee80211_tx_handler)(struct ieee80211_txrx_data *);
818static ieee80211_tx_handler ieee80211_tx_handlers[] =
820{ 819{
821 ieee80211_tx_h_check_assoc, 820 ieee80211_tx_h_check_assoc,
822 ieee80211_tx_h_sequence, 821 ieee80211_tx_h_sequence,
@@ -1158,7 +1157,7 @@ static int ieee80211_tx(struct net_device *dev, struct sk_buff *skb,
1158 sta = tx.sta; 1157 sta = tx.sta;
1159 tx.u.tx.channel = local->hw.conf.channel; 1158 tx.u.tx.channel = local->hw.conf.channel;
1160 1159
1161 for (handler = local->tx_handlers; *handler != NULL; 1160 for (handler = ieee80211_tx_handlers; *handler != NULL;
1162 handler++) { 1161 handler++) {
1163 res = (*handler)(&tx); 1162 res = (*handler)(&tx);
1164 if (res != TX_CONTINUE) 1163 if (res != TX_CONTINUE)
@@ -1914,7 +1913,7 @@ ieee80211_get_buffered_bc(struct ieee80211_hw *hw,
1914 tx.flags |= IEEE80211_TXRXD_TXPS_BUFFERED; 1913 tx.flags |= IEEE80211_TXRXD_TXPS_BUFFERED;
1915 tx.u.tx.channel = local->hw.conf.channel; 1914 tx.u.tx.channel = local->hw.conf.channel;
1916 1915
1917 for (handler = local->tx_handlers; *handler != NULL; handler++) { 1916 for (handler = ieee80211_tx_handlers; *handler != NULL; handler++) {
1918 res = (*handler)(&tx); 1917 res = (*handler)(&tx);
1919 if (res == TX_DROP || res == TX_QUEUED) 1918 if (res == TX_DROP || res == TX_QUEUED)
1920 break; 1919 break;