diff options
author | Johannes Berg <johannes@sipsolutions.net> | 2007-12-18 19:31:26 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-01-28 18:09:36 -0500 |
commit | 32bfd35d4b63bd63de4bb0d791ef049c3c868726 (patch) | |
tree | c1c213a35a00bcbe71a2ecc6521e19dec66cf6eb /include/net | |
parent | f653211197f3841f383fa9757ef8ce182c6cf627 (diff) |
mac80211: dont use interface indices in drivers
This patch gets rid of the if_id stuff where possible in favour of
a new per-virtual-interface structure "struct ieee80211_vif". This
structure is located at the end of the per-interface structure and
contains a variable length driver-use data area.
This has two advantages:
* removes the need to look up interfaces by if_id, this is better
for working with network namespaces and performance
* allows drivers to store and retrieve per-interface data without
having to allocate own lists/hash tables
Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'include/net')
-rw-r--r-- | include/net/mac80211.h | 70 |
1 files changed, 45 insertions, 25 deletions
diff --git a/include/net/mac80211.h b/include/net/mac80211.h index be2a383b4776..24a8ad3f5073 100644 --- a/include/net/mac80211.h +++ b/include/net/mac80211.h | |||
@@ -280,6 +280,7 @@ struct ieee80211_low_level_stats { | |||
280 | * the hardware to use given values (depending on what is supported). */ | 280 | * the hardware to use given values (depending on what is supported). */ |
281 | 281 | ||
282 | struct ieee80211_tx_control { | 282 | struct ieee80211_tx_control { |
283 | struct ieee80211_vif *vif; | ||
283 | int tx_rate; /* Transmit rate, given as the hw specific value for the | 284 | int tx_rate; /* Transmit rate, given as the hw specific value for the |
284 | * rate (from struct ieee80211_rate) */ | 285 | * rate (from struct ieee80211_rate) */ |
285 | int rts_cts_rate; /* Transmit rate for RTS/CTS frame, given as the hw | 286 | int rts_cts_rate; /* Transmit rate for RTS/CTS frame, given as the hw |
@@ -332,7 +333,6 @@ struct ieee80211_tx_control { | |||
332 | * packet dropping when probing higher rates, if hw | 333 | * packet dropping when probing higher rates, if hw |
333 | * supports multiple retry rates. -1 = not used */ | 334 | * supports multiple retry rates. -1 = not used */ |
334 | int type; /* internal */ | 335 | int type; /* internal */ |
335 | int ifindex; /* internal */ | ||
336 | }; | 336 | }; |
337 | 337 | ||
338 | 338 | ||
@@ -530,13 +530,25 @@ enum ieee80211_if_types { | |||
530 | }; | 530 | }; |
531 | 531 | ||
532 | /** | 532 | /** |
533 | * struct ieee80211_vif - per-interface data | ||
534 | * | ||
535 | * Data in this structure is continually present for driver | ||
536 | * use during the life of a virtual interface. | ||
537 | * | ||
538 | * @drv_priv: data area for driver use, will always be aligned to | ||
539 | * sizeof(void *). | ||
540 | */ | ||
541 | struct ieee80211_vif { | ||
542 | /* must be last */ | ||
543 | u8 drv_priv[0] __attribute__((__aligned__(sizeof(void *)))); | ||
544 | }; | ||
545 | |||
546 | /** | ||
533 | * struct ieee80211_if_init_conf - initial configuration of an interface | 547 | * struct ieee80211_if_init_conf - initial configuration of an interface |
534 | * | 548 | * |
535 | * @if_id: internal interface ID. This number has no particular meaning to | 549 | * @vif: pointer to a driver-use per-interface structure. The pointer |
536 | * drivers and the only allowed usage is to pass it to | 550 | * itself is also used for various functions including |
537 | * ieee80211_beacon_get() and ieee80211_get_buffered_bc() functions. | 551 | * ieee80211_beacon_get() and ieee80211_get_buffered_bc(). |
538 | * This field is not valid for monitor interfaces | ||
539 | * (interfaces of %IEEE80211_IF_TYPE_MNTR type). | ||
540 | * @type: one of &enum ieee80211_if_types constants. Determines the type of | 552 | * @type: one of &enum ieee80211_if_types constants. Determines the type of |
541 | * added/removed interface. | 553 | * added/removed interface. |
542 | * @mac_addr: pointer to MAC address of the interface. This pointer is valid | 554 | * @mac_addr: pointer to MAC address of the interface. This pointer is valid |
@@ -553,8 +565,8 @@ enum ieee80211_if_types { | |||
553 | * in pure monitor mode. | 565 | * in pure monitor mode. |
554 | */ | 566 | */ |
555 | struct ieee80211_if_init_conf { | 567 | struct ieee80211_if_init_conf { |
556 | int if_id; | ||
557 | enum ieee80211_if_types type; | 568 | enum ieee80211_if_types type; |
569 | struct ieee80211_vif *vif; | ||
558 | void *mac_addr; | 570 | void *mac_addr; |
559 | }; | 571 | }; |
560 | 572 | ||
@@ -757,6 +769,9 @@ enum ieee80211_hw_flags { | |||
757 | * @rate_control_algorithm: rate control algorithm for this hardware. | 769 | * @rate_control_algorithm: rate control algorithm for this hardware. |
758 | * If unset (NULL), the default algorithm will be used. Must be | 770 | * If unset (NULL), the default algorithm will be used. Must be |
759 | * set before calling ieee80211_register_hw(). | 771 | * set before calling ieee80211_register_hw(). |
772 | * | ||
773 | * @vif_data_size: size (in bytes) of the drv_priv data area | ||
774 | * within &struct ieee80211_vif. | ||
760 | */ | 775 | */ |
761 | struct ieee80211_hw { | 776 | struct ieee80211_hw { |
762 | struct ieee80211_conf conf; | 777 | struct ieee80211_conf conf; |
@@ -767,6 +782,7 @@ struct ieee80211_hw { | |||
767 | u32 flags; | 782 | u32 flags; |
768 | unsigned int extra_tx_headroom; | 783 | unsigned int extra_tx_headroom; |
769 | int channel_change_time; | 784 | int channel_change_time; |
785 | int vif_data_size; | ||
770 | u8 queues; | 786 | u8 queues; |
771 | s8 max_rssi; | 787 | s8 max_rssi; |
772 | s8 max_signal; | 788 | s8 max_signal; |
@@ -1076,7 +1092,8 @@ struct ieee80211_ops { | |||
1076 | struct ieee80211_if_init_conf *conf); | 1092 | struct ieee80211_if_init_conf *conf); |
1077 | int (*config)(struct ieee80211_hw *hw, struct ieee80211_conf *conf); | 1093 | int (*config)(struct ieee80211_hw *hw, struct ieee80211_conf *conf); |
1078 | int (*config_interface)(struct ieee80211_hw *hw, | 1094 | int (*config_interface)(struct ieee80211_hw *hw, |
1079 | int if_id, struct ieee80211_if_conf *conf); | 1095 | struct ieee80211_vif *vif, |
1096 | struct ieee80211_if_conf *conf); | ||
1080 | void (*configure_filter)(struct ieee80211_hw *hw, | 1097 | void (*configure_filter)(struct ieee80211_hw *hw, |
1081 | unsigned int changed_flags, | 1098 | unsigned int changed_flags, |
1082 | unsigned int *total_flags, | 1099 | unsigned int *total_flags, |
@@ -1094,7 +1111,7 @@ struct ieee80211_ops { | |||
1094 | int (*set_frag_threshold)(struct ieee80211_hw *hw, u32 value); | 1111 | int (*set_frag_threshold)(struct ieee80211_hw *hw, u32 value); |
1095 | int (*set_retry_limit)(struct ieee80211_hw *hw, | 1112 | int (*set_retry_limit)(struct ieee80211_hw *hw, |
1096 | u32 short_retry, u32 long_retr); | 1113 | u32 short_retry, u32 long_retr); |
1097 | void (*sta_notify)(struct ieee80211_hw *hw, int if_id, | 1114 | void (*sta_notify)(struct ieee80211_hw *hw, struct ieee80211_vif *vif, |
1098 | enum sta_notify_cmd, const u8 *addr); | 1115 | enum sta_notify_cmd, const u8 *addr); |
1099 | void (*erp_ie_changed)(struct ieee80211_hw *hw, u8 changes, | 1116 | void (*erp_ie_changed)(struct ieee80211_hw *hw, u8 changes, |
1100 | int cts_protection, int preamble); | 1117 | int cts_protection, int preamble); |
@@ -1309,7 +1326,7 @@ void ieee80211_tx_status_irqsafe(struct ieee80211_hw *hw, | |||
1309 | /** | 1326 | /** |
1310 | * ieee80211_beacon_get - beacon generation function | 1327 | * ieee80211_beacon_get - beacon generation function |
1311 | * @hw: pointer obtained from ieee80211_alloc_hw(). | 1328 | * @hw: pointer obtained from ieee80211_alloc_hw(). |
1312 | * @if_id: interface ID from &struct ieee80211_if_init_conf. | 1329 | * @vif: &struct ieee80211_vif pointer from &struct ieee80211_if_init_conf. |
1313 | * @control: will be filled with information needed to send this beacon. | 1330 | * @control: will be filled with information needed to send this beacon. |
1314 | * | 1331 | * |
1315 | * If the beacon frames are generated by the host system (i.e., not in | 1332 | * If the beacon frames are generated by the host system (i.e., not in |
@@ -1320,13 +1337,13 @@ void ieee80211_tx_status_irqsafe(struct ieee80211_hw *hw, | |||
1320 | * is responsible of freeing it. | 1337 | * is responsible of freeing it. |
1321 | */ | 1338 | */ |
1322 | struct sk_buff *ieee80211_beacon_get(struct ieee80211_hw *hw, | 1339 | struct sk_buff *ieee80211_beacon_get(struct ieee80211_hw *hw, |
1323 | int if_id, | 1340 | struct ieee80211_vif *vif, |
1324 | struct ieee80211_tx_control *control); | 1341 | struct ieee80211_tx_control *control); |
1325 | 1342 | ||
1326 | /** | 1343 | /** |
1327 | * ieee80211_rts_get - RTS frame generation function | 1344 | * ieee80211_rts_get - RTS frame generation function |
1328 | * @hw: pointer obtained from ieee80211_alloc_hw(). | 1345 | * @hw: pointer obtained from ieee80211_alloc_hw(). |
1329 | * @if_id: interface ID from &struct ieee80211_if_init_conf. | 1346 | * @vif: &struct ieee80211_vif pointer from &struct ieee80211_if_init_conf. |
1330 | * @frame: pointer to the frame that is going to be protected by the RTS. | 1347 | * @frame: pointer to the frame that is going to be protected by the RTS. |
1331 | * @frame_len: the frame length (in octets). | 1348 | * @frame_len: the frame length (in octets). |
1332 | * @frame_txctl: &struct ieee80211_tx_control of the frame. | 1349 | * @frame_txctl: &struct ieee80211_tx_control of the frame. |
@@ -1337,7 +1354,7 @@ struct sk_buff *ieee80211_beacon_get(struct ieee80211_hw *hw, | |||
1337 | * the next RTS frame from the 802.11 code. The low-level is responsible | 1354 | * the next RTS frame from the 802.11 code. The low-level is responsible |
1338 | * for calling this function before and RTS frame is needed. | 1355 | * for calling this function before and RTS frame is needed. |
1339 | */ | 1356 | */ |
1340 | void ieee80211_rts_get(struct ieee80211_hw *hw, int if_id, | 1357 | void ieee80211_rts_get(struct ieee80211_hw *hw, struct ieee80211_vif *vif, |
1341 | const void *frame, size_t frame_len, | 1358 | const void *frame, size_t frame_len, |
1342 | const struct ieee80211_tx_control *frame_txctl, | 1359 | const struct ieee80211_tx_control *frame_txctl, |
1343 | struct ieee80211_rts *rts); | 1360 | struct ieee80211_rts *rts); |
@@ -1345,7 +1362,7 @@ void ieee80211_rts_get(struct ieee80211_hw *hw, int if_id, | |||
1345 | /** | 1362 | /** |
1346 | * ieee80211_rts_duration - Get the duration field for an RTS frame | 1363 | * ieee80211_rts_duration - Get the duration field for an RTS frame |
1347 | * @hw: pointer obtained from ieee80211_alloc_hw(). | 1364 | * @hw: pointer obtained from ieee80211_alloc_hw(). |
1348 | * @if_id: interface ID from &struct ieee80211_if_init_conf. | 1365 | * @vif: &struct ieee80211_vif pointer from &struct ieee80211_if_init_conf. |
1349 | * @frame_len: the length of the frame that is going to be protected by the RTS. | 1366 | * @frame_len: the length of the frame that is going to be protected by the RTS. |
1350 | * @frame_txctl: &struct ieee80211_tx_control of the frame. | 1367 | * @frame_txctl: &struct ieee80211_tx_control of the frame. |
1351 | * | 1368 | * |
@@ -1353,14 +1370,14 @@ void ieee80211_rts_get(struct ieee80211_hw *hw, int if_id, | |||
1353 | * the duration field, the low-level driver uses this function to receive | 1370 | * the duration field, the low-level driver uses this function to receive |
1354 | * the duration field value in little-endian byteorder. | 1371 | * the duration field value in little-endian byteorder. |
1355 | */ | 1372 | */ |
1356 | __le16 ieee80211_rts_duration(struct ieee80211_hw *hw, int if_id, | 1373 | __le16 ieee80211_rts_duration(struct ieee80211_hw *hw, |
1357 | size_t frame_len, | 1374 | struct ieee80211_vif *vif, size_t frame_len, |
1358 | const struct ieee80211_tx_control *frame_txctl); | 1375 | const struct ieee80211_tx_control *frame_txctl); |
1359 | 1376 | ||
1360 | /** | 1377 | /** |
1361 | * ieee80211_ctstoself_get - CTS-to-self frame generation function | 1378 | * ieee80211_ctstoself_get - CTS-to-self frame generation function |
1362 | * @hw: pointer obtained from ieee80211_alloc_hw(). | 1379 | * @hw: pointer obtained from ieee80211_alloc_hw(). |
1363 | * @if_id: interface ID from &struct ieee80211_if_init_conf. | 1380 | * @vif: &struct ieee80211_vif pointer from &struct ieee80211_if_init_conf. |
1364 | * @frame: pointer to the frame that is going to be protected by the CTS-to-self. | 1381 | * @frame: pointer to the frame that is going to be protected by the CTS-to-self. |
1365 | * @frame_len: the frame length (in octets). | 1382 | * @frame_len: the frame length (in octets). |
1366 | * @frame_txctl: &struct ieee80211_tx_control of the frame. | 1383 | * @frame_txctl: &struct ieee80211_tx_control of the frame. |
@@ -1371,7 +1388,8 @@ __le16 ieee80211_rts_duration(struct ieee80211_hw *hw, int if_id, | |||
1371 | * the next CTS-to-self frame from the 802.11 code. The low-level is responsible | 1388 | * the next CTS-to-self frame from the 802.11 code. The low-level is responsible |
1372 | * for calling this function before and CTS-to-self frame is needed. | 1389 | * for calling this function before and CTS-to-self frame is needed. |
1373 | */ | 1390 | */ |
1374 | void ieee80211_ctstoself_get(struct ieee80211_hw *hw, int if_id, | 1391 | void ieee80211_ctstoself_get(struct ieee80211_hw *hw, |
1392 | struct ieee80211_vif *vif, | ||
1375 | const void *frame, size_t frame_len, | 1393 | const void *frame, size_t frame_len, |
1376 | const struct ieee80211_tx_control *frame_txctl, | 1394 | const struct ieee80211_tx_control *frame_txctl, |
1377 | struct ieee80211_cts *cts); | 1395 | struct ieee80211_cts *cts); |
@@ -1379,7 +1397,7 @@ void ieee80211_ctstoself_get(struct ieee80211_hw *hw, int if_id, | |||
1379 | /** | 1397 | /** |
1380 | * ieee80211_ctstoself_duration - Get the duration field for a CTS-to-self frame | 1398 | * ieee80211_ctstoself_duration - Get the duration field for a CTS-to-self frame |
1381 | * @hw: pointer obtained from ieee80211_alloc_hw(). | 1399 | * @hw: pointer obtained from ieee80211_alloc_hw(). |
1382 | * @if_id: interface ID from &struct ieee80211_if_init_conf. | 1400 | * @vif: &struct ieee80211_vif pointer from &struct ieee80211_if_init_conf. |
1383 | * @frame_len: the length of the frame that is going to be protected by the CTS-to-self. | 1401 | * @frame_len: the length of the frame that is going to be protected by the CTS-to-self. |
1384 | * @frame_txctl: &struct ieee80211_tx_control of the frame. | 1402 | * @frame_txctl: &struct ieee80211_tx_control of the frame. |
1385 | * | 1403 | * |
@@ -1387,28 +1405,30 @@ void ieee80211_ctstoself_get(struct ieee80211_hw *hw, int if_id, | |||
1387 | * the duration field, the low-level driver uses this function to receive | 1405 | * the duration field, the low-level driver uses this function to receive |
1388 | * the duration field value in little-endian byteorder. | 1406 | * the duration field value in little-endian byteorder. |
1389 | */ | 1407 | */ |
1390 | __le16 ieee80211_ctstoself_duration(struct ieee80211_hw *hw, int if_id, | 1408 | __le16 ieee80211_ctstoself_duration(struct ieee80211_hw *hw, |
1409 | struct ieee80211_vif *vif, | ||
1391 | size_t frame_len, | 1410 | size_t frame_len, |
1392 | const struct ieee80211_tx_control *frame_txctl); | 1411 | const struct ieee80211_tx_control *frame_txctl); |
1393 | 1412 | ||
1394 | /** | 1413 | /** |
1395 | * ieee80211_generic_frame_duration - Calculate the duration field for a frame | 1414 | * ieee80211_generic_frame_duration - Calculate the duration field for a frame |
1396 | * @hw: pointer obtained from ieee80211_alloc_hw(). | 1415 | * @hw: pointer obtained from ieee80211_alloc_hw(). |
1397 | * @if_id: interface ID from &struct ieee80211_if_init_conf. | 1416 | * @vif: &struct ieee80211_vif pointer from &struct ieee80211_if_init_conf. |
1398 | * @frame_len: the length of the frame. | 1417 | * @frame_len: the length of the frame. |
1399 | * @rate: the rate (in 100kbps) at which the frame is going to be transmitted. | 1418 | * @rate: the rate (in 100kbps) at which the frame is going to be transmitted. |
1400 | * | 1419 | * |
1401 | * Calculate the duration field of some generic frame, given its | 1420 | * Calculate the duration field of some generic frame, given its |
1402 | * length and transmission rate (in 100kbps). | 1421 | * length and transmission rate (in 100kbps). |
1403 | */ | 1422 | */ |
1404 | __le16 ieee80211_generic_frame_duration(struct ieee80211_hw *hw, int if_id, | 1423 | __le16 ieee80211_generic_frame_duration(struct ieee80211_hw *hw, |
1424 | struct ieee80211_vif *vif, | ||
1405 | size_t frame_len, | 1425 | size_t frame_len, |
1406 | int rate); | 1426 | int rate); |
1407 | 1427 | ||
1408 | /** | 1428 | /** |
1409 | * ieee80211_get_buffered_bc - accessing buffered broadcast and multicast frames | 1429 | * ieee80211_get_buffered_bc - accessing buffered broadcast and multicast frames |
1410 | * @hw: pointer as obtained from ieee80211_alloc_hw(). | 1430 | * @hw: pointer as obtained from ieee80211_alloc_hw(). |
1411 | * @if_id: interface ID from &struct ieee80211_if_init_conf. | 1431 | * @vif: &struct ieee80211_vif pointer from &struct ieee80211_if_init_conf. |
1412 | * @control: will be filled with information needed to send returned frame. | 1432 | * @control: will be filled with information needed to send returned frame. |
1413 | * | 1433 | * |
1414 | * Function for accessing buffered broadcast and multicast frames. If | 1434 | * Function for accessing buffered broadcast and multicast frames. If |
@@ -1427,7 +1447,7 @@ __le16 ieee80211_generic_frame_duration(struct ieee80211_hw *hw, int if_id, | |||
1427 | * use common code for all beacons. | 1447 | * use common code for all beacons. |
1428 | */ | 1448 | */ |
1429 | struct sk_buff * | 1449 | struct sk_buff * |
1430 | ieee80211_get_buffered_bc(struct ieee80211_hw *hw, int if_id, | 1450 | ieee80211_get_buffered_bc(struct ieee80211_hw *hw, struct ieee80211_vif *vif, |
1431 | struct ieee80211_tx_control *control); | 1451 | struct ieee80211_tx_control *control); |
1432 | 1452 | ||
1433 | /** | 1453 | /** |
@@ -1517,7 +1537,7 @@ void ieee80211_scan_completed(struct ieee80211_hw *hw); | |||
1517 | */ | 1537 | */ |
1518 | void ieee80211_iterate_active_interfaces(struct ieee80211_hw *hw, | 1538 | void ieee80211_iterate_active_interfaces(struct ieee80211_hw *hw, |
1519 | void (*iterator)(void *data, u8 *mac, | 1539 | void (*iterator)(void *data, u8 *mac, |
1520 | int if_id), | 1540 | struct ieee80211_vif *vif), |
1521 | void *data); | 1541 | void *data); |
1522 | 1542 | ||
1523 | #endif /* MAC80211_H */ | 1543 | #endif /* MAC80211_H */ |