diff options
author | Winkler, Tomas <tomas.winkler@intel.com> | 2008-12-21 22:31:23 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-01-29 15:59:27 -0500 |
commit | 51af3d3fbbe326077a7e245268a7de325de6ecd2 (patch) | |
tree | 5cf3010f1cdd86d58f0b234be9eb8fa65d032fc9 /drivers/net/wireless/iwlwifi/iwl3945-base.c | |
parent | e52119c50d6a35506b1c063eeacf7acc40b4e03d (diff) |
iwl3945: use rx queue management infrastructure from iwlcore
This patch uses rx queue alloc free and reset function from iwlcore.
This should fix the regression reported by Kalle Valo.
Signed-off-by: Tomas Winkler <tomas.winkler@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/iwlwifi/iwl3945-base.c')
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl3945-base.c | 81 |
1 files changed, 1 insertions, 80 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl3945-base.c b/drivers/net/wireless/iwlwifi/iwl3945-base.c index 0059d2889314..a176f42fd7cf 100644 --- a/drivers/net/wireless/iwlwifi/iwl3945-base.c +++ b/drivers/net/wireless/iwlwifi/iwl3945-base.c | |||
@@ -3186,7 +3186,6 @@ static void iwl3945_tx_cmd_complete(struct iwl_priv *priv, | |||
3186 | * | 3186 | * |
3187 | * Driver sequence: | 3187 | * Driver sequence: |
3188 | * | 3188 | * |
3189 | * iwl3945_rx_queue_alloc() Allocates rx_free | ||
3190 | * iwl3945_rx_replenish() Replenishes rx_free list from rx_used, and calls | 3189 | * iwl3945_rx_replenish() Replenishes rx_free list from rx_used, and calls |
3191 | * iwl3945_rx_queue_restock | 3190 | * iwl3945_rx_queue_restock |
3192 | * iwl3945_rx_queue_restock() Moves available buffers from rx_free into Rx | 3191 | * iwl3945_rx_queue_restock() Moves available buffers from rx_free into Rx |
@@ -3405,84 +3404,6 @@ void iwl3945_rx_replenish(void *data) | |||
3405 | spin_unlock_irqrestore(&priv->lock, flags); | 3404 | spin_unlock_irqrestore(&priv->lock, flags); |
3406 | } | 3405 | } |
3407 | 3406 | ||
3408 | /* Assumes that the skb field of the buffers in 'pool' is kept accurate. | ||
3409 | * If an SKB has been detached, the POOL needs to have its SKB set to NULL | ||
3410 | * This free routine walks the list of POOL entries and if SKB is set to | ||
3411 | * non NULL it is unmapped and freed | ||
3412 | */ | ||
3413 | static void iwl3945_rx_queue_free(struct iwl_priv *priv, struct iwl_rx_queue *rxq) | ||
3414 | { | ||
3415 | int i; | ||
3416 | for (i = 0; i < RX_QUEUE_SIZE + RX_FREE_BUFFERS; i++) { | ||
3417 | if (rxq->pool[i].skb != NULL) { | ||
3418 | pci_unmap_single(priv->pci_dev, | ||
3419 | rxq->pool[i].real_dma_addr, | ||
3420 | IWL_RX_BUF_SIZE, PCI_DMA_FROMDEVICE); | ||
3421 | dev_kfree_skb(rxq->pool[i].skb); | ||
3422 | } | ||
3423 | } | ||
3424 | |||
3425 | pci_free_consistent(priv->pci_dev, 4 * RX_QUEUE_SIZE, rxq->bd, | ||
3426 | rxq->dma_addr); | ||
3427 | rxq->bd = NULL; | ||
3428 | } | ||
3429 | |||
3430 | int iwl3945_rx_queue_alloc(struct iwl_priv *priv) | ||
3431 | { | ||
3432 | struct iwl_rx_queue *rxq = &priv->rxq; | ||
3433 | struct pci_dev *dev = priv->pci_dev; | ||
3434 | int i; | ||
3435 | |||
3436 | spin_lock_init(&rxq->lock); | ||
3437 | INIT_LIST_HEAD(&rxq->rx_free); | ||
3438 | INIT_LIST_HEAD(&rxq->rx_used); | ||
3439 | |||
3440 | /* Alloc the circular buffer of Read Buffer Descriptors (RBDs) */ | ||
3441 | rxq->bd = pci_alloc_consistent(dev, 4 * RX_QUEUE_SIZE, &rxq->dma_addr); | ||
3442 | if (!rxq->bd) | ||
3443 | return -ENOMEM; | ||
3444 | |||
3445 | /* Fill the rx_used queue with _all_ of the Rx buffers */ | ||
3446 | for (i = 0; i < RX_FREE_BUFFERS + RX_QUEUE_SIZE; i++) | ||
3447 | list_add_tail(&rxq->pool[i].list, &rxq->rx_used); | ||
3448 | |||
3449 | /* Set us so that we have processed and used all buffers, but have | ||
3450 | * not restocked the Rx queue with fresh buffers */ | ||
3451 | rxq->read = rxq->write = 0; | ||
3452 | rxq->free_count = 0; | ||
3453 | rxq->need_update = 0; | ||
3454 | return 0; | ||
3455 | } | ||
3456 | |||
3457 | void iwl3945_rx_queue_reset(struct iwl_priv *priv, struct iwl_rx_queue *rxq) | ||
3458 | { | ||
3459 | unsigned long flags; | ||
3460 | int i; | ||
3461 | spin_lock_irqsave(&rxq->lock, flags); | ||
3462 | INIT_LIST_HEAD(&rxq->rx_free); | ||
3463 | INIT_LIST_HEAD(&rxq->rx_used); | ||
3464 | /* Fill the rx_used queue with _all_ of the Rx buffers */ | ||
3465 | for (i = 0; i < RX_FREE_BUFFERS + RX_QUEUE_SIZE; i++) { | ||
3466 | /* In the reset function, these buffers may have been allocated | ||
3467 | * to an SKB, so we need to unmap and free potential storage */ | ||
3468 | if (rxq->pool[i].skb != NULL) { | ||
3469 | pci_unmap_single(priv->pci_dev, | ||
3470 | rxq->pool[i].real_dma_addr, | ||
3471 | IWL_RX_BUF_SIZE, PCI_DMA_FROMDEVICE); | ||
3472 | priv->alloc_rxb_skb--; | ||
3473 | dev_kfree_skb(rxq->pool[i].skb); | ||
3474 | rxq->pool[i].skb = NULL; | ||
3475 | } | ||
3476 | list_add_tail(&rxq->pool[i].list, &rxq->rx_used); | ||
3477 | } | ||
3478 | |||
3479 | /* Set us so that we have processed and used all buffers, but have | ||
3480 | * not restocked the Rx queue with fresh buffers */ | ||
3481 | rxq->read = rxq->write = 0; | ||
3482 | rxq->free_count = 0; | ||
3483 | spin_unlock_irqrestore(&rxq->lock, flags); | ||
3484 | } | ||
3485 | |||
3486 | /* Convert linear signal-to-noise ratio into dB */ | 3407 | /* Convert linear signal-to-noise ratio into dB */ |
3487 | static u8 ratio2dB[100] = { | 3408 | static u8 ratio2dB[100] = { |
3488 | /* 0 1 2 3 4 5 6 7 8 9 */ | 3409 | /* 0 1 2 3 4 5 6 7 8 9 */ |
@@ -7731,7 +7652,7 @@ static void __devexit iwl3945_pci_remove(struct pci_dev *pdev) | |||
7731 | iwl3945_dealloc_ucode_pci(priv); | 7652 | iwl3945_dealloc_ucode_pci(priv); |
7732 | 7653 | ||
7733 | if (priv->rxq.bd) | 7654 | if (priv->rxq.bd) |
7734 | iwl3945_rx_queue_free(priv, &priv->rxq); | 7655 | iwl_rx_queue_free(priv, &priv->rxq); |
7735 | iwl3945_hw_txq_ctx_free(priv); | 7656 | iwl3945_hw_txq_ctx_free(priv); |
7736 | 7657 | ||
7737 | iwl3945_unset_hw_params(priv); | 7658 | iwl3945_unset_hw_params(priv); |