aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-5000-hw.h4
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-5000.c49
2 files changed, 53 insertions, 0 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-5000-hw.h b/drivers/net/wireless/iwlwifi/iwl-5000-hw.h
index 31592fb8ddfd..9e557ce315b7 100644
--- a/drivers/net/wireless/iwlwifi/iwl-5000-hw.h
+++ b/drivers/net/wireless/iwlwifi/iwl-5000-hw.h
@@ -83,6 +83,10 @@
83#define IWL50_NUM_QUEUES 20 83#define IWL50_NUM_QUEUES 20
84#define IWL50_BACK_QUEUE_FIRST_ID 10 84#define IWL50_BACK_QUEUE_FIRST_ID 10
85 85
86#define IWL_sta_id_POS 12
87#define IWL_sta_id_LEN 4
88#define IWL_sta_id_SYM val
89
86/* Fixed (non-configurable) rx data from phy */ 90/* Fixed (non-configurable) rx data from phy */
87 91
88/* Base physical address of iwl5000_shared is provided to SCD_DRAM_BASE_ADDR 92/* Base physical address of iwl5000_shared is provided to SCD_DRAM_BASE_ADDR
diff --git a/drivers/net/wireless/iwlwifi/iwl-5000.c b/drivers/net/wireless/iwlwifi/iwl-5000.c
index 8e2a6a5749a1..1e63b497471d 100644
--- a/drivers/net/wireless/iwlwifi/iwl-5000.c
+++ b/drivers/net/wireless/iwlwifi/iwl-5000.c
@@ -314,6 +314,54 @@ static void iwl5000_free_shared_mem(struct iwl_priv *priv)
314 priv->shared_phys); 314 priv->shared_phys);
315} 315}
316 316
317/**
318 * iwl5000_txq_update_byte_cnt_tbl - Set up entry in Tx byte-count array
319 */
320static void iwl5000_txq_update_byte_cnt_tbl(struct iwl_priv *priv,
321 struct iwl4965_tx_queue *txq,
322 u16 byte_cnt)
323{
324 struct iwl5000_shared *shared_data = priv->shared_virt;
325 int txq_id = txq->q.id;
326 u8 sec_ctl = 0;
327 u8 sta = 0;
328 int len;
329
330 len = byte_cnt + IWL_TX_CRC_SIZE + IWL_TX_DELIMITER_SIZE;
331
332 if (txq_id != IWL_CMD_QUEUE_NUM) {
333 sta = txq->cmd[txq->q.write_ptr].cmd.tx.sta_id;
334 sec_ctl = txq->cmd[txq->q.write_ptr].cmd.tx.sec_ctl;
335
336 switch (sec_ctl & TX_CMD_SEC_MSK) {
337 case TX_CMD_SEC_CCM:
338 len += CCMP_MIC_LEN;
339 break;
340 case TX_CMD_SEC_TKIP:
341 len += TKIP_ICV_LEN;
342 break;
343 case TX_CMD_SEC_WEP:
344 len += WEP_IV_LEN + WEP_ICV_LEN;
345 break;
346 }
347 }
348
349 IWL_SET_BITS16(shared_data->queues_byte_cnt_tbls[txq_id].
350 tfd_offset[txq->q.write_ptr], byte_cnt, len);
351
352 IWL_SET_BITS16(shared_data->queues_byte_cnt_tbls[txq_id].
353 tfd_offset[txq->q.write_ptr], sta_id, sta);
354
355 if (txq->q.write_ptr < IWL50_MAX_WIN_SIZE) {
356 IWL_SET_BITS16(shared_data->queues_byte_cnt_tbls[txq_id].
357 tfd_offset[IWL50_QUEUE_SIZE + txq->q.write_ptr],
358 byte_cnt, len);
359 IWL_SET_BITS16(shared_data->queues_byte_cnt_tbls[txq_id].
360 tfd_offset[IWL50_QUEUE_SIZE + txq->q.write_ptr],
361 sta_id, sta);
362 }
363}
364
317static struct iwl_hcmd_ops iwl5000_hcmd = { 365static struct iwl_hcmd_ops iwl5000_hcmd = {
318}; 366};
319 367
@@ -328,6 +376,7 @@ static struct iwl_lib_ops iwl5000_lib = {
328 .set_hw_params = iwl5000_hw_set_hw_params, 376 .set_hw_params = iwl5000_hw_set_hw_params,
329 .alloc_shared_mem = iwl5000_alloc_shared_mem, 377 .alloc_shared_mem = iwl5000_alloc_shared_mem,
330 .free_shared_mem = iwl5000_free_shared_mem, 378 .free_shared_mem = iwl5000_free_shared_mem,
379 .txq_update_byte_cnt_tbl = iwl5000_txq_update_byte_cnt_tbl,
331 .apm_ops = { 380 .apm_ops = {
332 .init = iwl5000_apm_init, 381 .init = iwl5000_apm_init,
333 .set_pwr_src = iwl4965_set_pwr_src, 382 .set_pwr_src = iwl4965_set_pwr_src,