diff options
author | Ben Cahill <ben.m.cahill@intel.com> | 2007-11-28 22:09:49 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-01-28 18:05:19 -0500 |
commit | bc47279f558e7e9ea70dad1d484d2816ec239bb0 (patch) | |
tree | be0b2be7b15e70df44f85f5c8bd8c3b9f21bc69d /drivers/net/wireless | |
parent | 81cd110d818dd4649cbac17f95f698a24c7acc45 (diff) |
iwlwifi: Add comments to some driver data structures
Add comments to some driver data structures
Remove unused "sched_retry" member from struct iwl3945_tx_queue
Signed-off-by: Ben Cahill <ben.m.cahill@intel.com>
Signed-off-by: Zhu Yi <yi.zhu@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless')
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-3945.h | 35 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-4965.h | 58 |
2 files changed, 82 insertions, 11 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-3945.h b/drivers/net/wireless/iwlwifi/iwl-3945.h index 02040ef10da0..607a1ed542fb 100644 --- a/drivers/net/wireless/iwlwifi/iwl-3945.h +++ b/drivers/net/wireless/iwlwifi/iwl-3945.h | |||
@@ -130,6 +130,7 @@ struct iwl3945_queue { | |||
130 | 130 | ||
131 | #define MAX_NUM_OF_TBS (20) | 131 | #define MAX_NUM_OF_TBS (20) |
132 | 132 | ||
133 | /* One for each TFD */ | ||
133 | struct iwl3945_tx_info { | 134 | struct iwl3945_tx_info { |
134 | struct ieee80211_tx_status status; | 135 | struct ieee80211_tx_status status; |
135 | struct sk_buff *skb[MAX_NUM_OF_TBS]; | 136 | struct sk_buff *skb[MAX_NUM_OF_TBS]; |
@@ -137,10 +138,15 @@ struct iwl3945_tx_info { | |||
137 | 138 | ||
138 | /** | 139 | /** |
139 | * struct iwl3945_tx_queue - Tx Queue for DMA | 140 | * struct iwl3945_tx_queue - Tx Queue for DMA |
140 | * @need_update: need to update read/write index | 141 | * @q: generic Rx/Tx queue descriptor |
141 | * @shed_retry: queue is HT AGG enabled | 142 | * @bd: base of circular buffer of TFDs |
143 | * @cmd: array of command/Tx buffers | ||
144 | * @dma_addr_cmd: physical address of cmd/tx buffer array | ||
145 | * @txb: array of per-TFD driver data | ||
146 | * @need_update: indicates need to update read/write index | ||
142 | * | 147 | * |
143 | * Queue consists of circular buffer of BD's and required locking structures. | 148 | * A Tx queue consists of circular buffer of BDs (a.k.a. TFDs, transmit frame |
149 | * descriptors) and required locking structures. | ||
144 | */ | 150 | */ |
145 | struct iwl3945_tx_queue { | 151 | struct iwl3945_tx_queue { |
146 | struct iwl3945_queue q; | 152 | struct iwl3945_queue q; |
@@ -149,7 +155,6 @@ struct iwl3945_tx_queue { | |||
149 | dma_addr_t dma_addr_cmd; | 155 | dma_addr_t dma_addr_cmd; |
150 | struct iwl3945_tx_info *txb; | 156 | struct iwl3945_tx_info *txb; |
151 | int need_update; | 157 | int need_update; |
152 | int sched_retry; | ||
153 | int active; | 158 | int active; |
154 | }; | 159 | }; |
155 | 160 | ||
@@ -325,6 +330,13 @@ struct iwl3945_cmd_meta { | |||
325 | 330 | ||
326 | } __attribute__ ((packed)); | 331 | } __attribute__ ((packed)); |
327 | 332 | ||
333 | /** | ||
334 | * struct iwl3945_cmd | ||
335 | * | ||
336 | * For allocation of the command and tx queues, this establishes the overall | ||
337 | * size of the largest command we send to uCode, except for a scan command | ||
338 | * (which is relatively huge; space is allocated separately). | ||
339 | */ | ||
328 | struct iwl3945_cmd { | 340 | struct iwl3945_cmd { |
329 | struct iwl3945_cmd_meta meta; | 341 | struct iwl3945_cmd_meta meta; |
330 | struct iwl3945_cmd_header hdr; | 342 | struct iwl3945_cmd_header hdr; |
@@ -522,6 +534,19 @@ struct iwl3945_ibss_seq { | |||
522 | struct list_head list; | 534 | struct list_head list; |
523 | }; | 535 | }; |
524 | 536 | ||
537 | /** | ||
538 | * struct iwl4965_driver_hw_info | ||
539 | * @max_txq_num: Max # Tx queues supported | ||
540 | * @ac_queue_count: # Tx queues for EDCA Access Categories (AC) | ||
541 | * @tx_cmd_len: Size of Tx command (but not including frame itself) | ||
542 | * @max_rxq_size: Max # Rx frames in Rx queue (must be power-of-2) | ||
543 | * @rx_buffer_size: | ||
544 | * @max_rxq_log: Log-base-2 of max_rxq_size | ||
545 | * @max_stations: | ||
546 | * @bcast_sta_id: | ||
547 | * @shared_virt: Pointer to driver/uCode shared Tx Byte Counts and Rx status | ||
548 | * @shared_phys: Physical Pointer to Tx Byte Counts and Rx status | ||
549 | */ | ||
525 | struct iwl3945_driver_hw_info { | 550 | struct iwl3945_driver_hw_info { |
526 | u16 max_txq_num; | 551 | u16 max_txq_num; |
527 | u16 ac_queue_count; | 552 | u16 ac_queue_count; |
@@ -857,6 +882,8 @@ struct iwl3945_priv { | |||
857 | u16 last_seq_num; | 882 | u16 last_seq_num; |
858 | u16 last_frag_num; | 883 | u16 last_frag_num; |
859 | unsigned long last_packet_time; | 884 | unsigned long last_packet_time; |
885 | |||
886 | /* Hash table for finding stations in IBSS network */ | ||
860 | struct list_head ibss_mac_hash[IWL_IBSS_MAC_HASH_SIZE]; | 887 | struct list_head ibss_mac_hash[IWL_IBSS_MAC_HASH_SIZE]; |
861 | 888 | ||
862 | /* eeprom */ | 889 | /* eeprom */ |
diff --git a/drivers/net/wireless/iwlwifi/iwl-4965.h b/drivers/net/wireless/iwlwifi/iwl-4965.h index d0abbb3a5ac7..30001482c485 100644 --- a/drivers/net/wireless/iwlwifi/iwl-4965.h +++ b/drivers/net/wireless/iwlwifi/iwl-4965.h | |||
@@ -129,6 +129,7 @@ struct iwl4965_queue { | |||
129 | 129 | ||
130 | #define MAX_NUM_OF_TBS (20) | 130 | #define MAX_NUM_OF_TBS (20) |
131 | 131 | ||
132 | /* One for each TFD */ | ||
132 | struct iwl4965_tx_info { | 133 | struct iwl4965_tx_info { |
133 | struct ieee80211_tx_status status; | 134 | struct ieee80211_tx_status status; |
134 | struct sk_buff *skb[MAX_NUM_OF_TBS]; | 135 | struct sk_buff *skb[MAX_NUM_OF_TBS]; |
@@ -136,10 +137,16 @@ struct iwl4965_tx_info { | |||
136 | 137 | ||
137 | /** | 138 | /** |
138 | * struct iwl4965_tx_queue - Tx Queue for DMA | 139 | * struct iwl4965_tx_queue - Tx Queue for DMA |
139 | * @need_update: need to update read/write index | 140 | * @q: generic Rx/Tx queue descriptor |
140 | * @shed_retry: queue is HT AGG enabled | 141 | * @bd: base of circular buffer of TFDs |
142 | * @cmd: array of command/Tx buffers | ||
143 | * @dma_addr_cmd: physical address of cmd/tx buffer array | ||
144 | * @txb: array of per-TFD driver data | ||
145 | * @need_update: indicates need to update read/write index | ||
146 | * @sched_retry: indicates queue is high-throughput aggregation (HT AGG) enabled | ||
141 | * | 147 | * |
142 | * Queue consists of circular buffer of BD's and required locking structures. | 148 | * A Tx queue consists of circular buffer of BDs (a.k.a. TFDs, transmit frame |
149 | * descriptors) and required locking structures. | ||
143 | */ | 150 | */ |
144 | struct iwl4965_tx_queue { | 151 | struct iwl4965_tx_queue { |
145 | struct iwl4965_queue q; | 152 | struct iwl4965_queue q; |
@@ -332,9 +339,16 @@ struct iwl4965_cmd_meta { | |||
332 | 339 | ||
333 | } __attribute__ ((packed)); | 340 | } __attribute__ ((packed)); |
334 | 341 | ||
342 | /** | ||
343 | * struct iwl4965_cmd | ||
344 | * | ||
345 | * For allocation of the command and tx queues, this establishes the overall | ||
346 | * size of the largest command we send to uCode, except for a scan command | ||
347 | * (which is relatively huge; space is allocated separately). | ||
348 | */ | ||
335 | struct iwl4965_cmd { | 349 | struct iwl4965_cmd { |
336 | struct iwl4965_cmd_meta meta; | 350 | struct iwl4965_cmd_meta meta; /* driver data */ |
337 | struct iwl4965_cmd_header hdr; | 351 | struct iwl4965_cmd_header hdr; /* uCode API */ |
338 | union { | 352 | union { |
339 | struct iwl4965_addsta_cmd addsta; | 353 | struct iwl4965_addsta_cmd addsta; |
340 | struct iwl4965_led_cmd led; | 354 | struct iwl4965_led_cmd led; |
@@ -436,6 +450,20 @@ struct iwl4965_rx_queue { | |||
436 | 450 | ||
437 | #ifdef CONFIG_IWL4965_HT | 451 | #ifdef CONFIG_IWL4965_HT |
438 | #ifdef CONFIG_IWL4965_HT_AGG | 452 | #ifdef CONFIG_IWL4965_HT_AGG |
453 | /** | ||
454 | * struct iwl4965_ht_agg -- aggregation status while waiting for block-ack | ||
455 | * @txq_id: Tx queue used for Tx attempt | ||
456 | * @frame_count: # frames attempted by Tx command | ||
457 | * @wait_for_ba: Expect block-ack before next Tx reply | ||
458 | * @start_idx: Index of 1st Transmit Frame Descriptor (TFD) in Tx window | ||
459 | * @bitmap0: Low order bitmap, one bit for each frame pending ACK in Tx window | ||
460 | * @bitmap1: High order, one bit for each frame pending ACK in Tx window | ||
461 | * @rate_n_flags: Rate at which Tx was attempted | ||
462 | * | ||
463 | * If REPLY_TX indicates that aggregation was attempted, driver must wait | ||
464 | * for block ack (REPLY_COMPRESSED_BA). This struct stores tx reply info | ||
465 | * until block ack arrives. | ||
466 | */ | ||
439 | struct iwl4965_ht_agg { | 467 | struct iwl4965_ht_agg { |
440 | u16 txq_id; | 468 | u16 txq_id; |
441 | u16 frame_count; | 469 | u16 frame_count; |
@@ -566,6 +594,19 @@ struct iwl4965_ibss_seq { | |||
566 | struct list_head list; | 594 | struct list_head list; |
567 | }; | 595 | }; |
568 | 596 | ||
597 | /** | ||
598 | * struct iwl4965_driver_hw_info | ||
599 | * @max_txq_num: Max # Tx queues supported | ||
600 | * @ac_queue_count: # Tx queues for EDCA Access Categories (AC) | ||
601 | * @tx_cmd_len: Size of Tx command (but not including frame itself) | ||
602 | * @max_rxq_size: Max # Rx frames in Rx queue (must be power-of-2) | ||
603 | * @rx_buffer_size: | ||
604 | * @max_rxq_log: Log-base-2 of max_rxq_size | ||
605 | * @max_stations: | ||
606 | * @bcast_sta_id: | ||
607 | * @shared_virt: Pointer to driver/uCode shared Tx Byte Counts and Rx status | ||
608 | * @shared_phys: Physical Pointer to Tx Byte Counts and Rx status | ||
609 | */ | ||
569 | struct iwl4965_driver_hw_info { | 610 | struct iwl4965_driver_hw_info { |
570 | u16 max_txq_num; | 611 | u16 max_txq_num; |
571 | u16 ac_queue_count; | 612 | u16 ac_queue_count; |
@@ -1149,10 +1190,11 @@ struct iwl4965_priv { | |||
1149 | u8 call_post_assoc_from_beacon; | 1190 | u8 call_post_assoc_from_beacon; |
1150 | u8 assoc_station_added; | 1191 | u8 assoc_station_added; |
1151 | u8 use_ant_b_for_management_frame; /* Tx antenna selection */ | 1192 | u8 use_ant_b_for_management_frame; /* Tx antenna selection */ |
1152 | /* HT variables */ | 1193 | |
1194 | /* High Throughput (HT) variables */ | ||
1153 | u8 is_dup; | 1195 | u8 is_dup; |
1154 | u8 is_ht_enabled; | 1196 | u8 is_ht_enabled; |
1155 | u8 channel_width; /* 0=20MHZ, 1=40MHZ */ | 1197 | u8 channel_width; /* 0=20MHZ, 1=40MHZ supported */ |
1156 | u8 current_channel_width; | 1198 | u8 current_channel_width; |
1157 | u8 valid_antenna; /* Bit mask of antennas actually connected */ | 1199 | u8 valid_antenna; /* Bit mask of antennas actually connected */ |
1158 | #ifdef CONFIG_IWL4965_SENSITIVITY | 1200 | #ifdef CONFIG_IWL4965_SENSITIVITY |
@@ -1229,6 +1271,8 @@ struct iwl4965_priv { | |||
1229 | u16 last_seq_num; | 1271 | u16 last_seq_num; |
1230 | u16 last_frag_num; | 1272 | u16 last_frag_num; |
1231 | unsigned long last_packet_time; | 1273 | unsigned long last_packet_time; |
1274 | |||
1275 | /* Hash table for finding stations in IBSS network */ | ||
1232 | struct list_head ibss_mac_hash[IWL_IBSS_MAC_HASH_SIZE]; | 1276 | struct list_head ibss_mac_hash[IWL_IBSS_MAC_HASH_SIZE]; |
1233 | 1277 | ||
1234 | /* eeprom */ | 1278 | /* eeprom */ |