ath5k: remove some unneeded error handling code
authorDan Carpenter <dan.carpenter@oracle.com>
Wed, 5 Oct 2011 05:46:37 +0000 (08:46 +0300)
committerJohn W. Linville <linville@tuxdriver.com>
Tue, 11 Oct 2011 20:41:09 +0000 (16:41 -0400)
th5k_hw_setup_tx_queue() returns a valid offset into the ah->ah_txq[]
array.  The ah->ah_txq[] and the ah->txqs[] array are the same size.
Both have AR5K_NUM_TX_QUEUES elements.  So this error handling code
will never trigger.

Also it's wrong.  The call to ath5k_hw_release_tx_queue() with a qnum
of AR5K_NUM_TX_QUEUES or more will just trigger a WARN_ON() and
return.  Or if it missed the WARN_ON(), it would just corrupt some
memory and return.

Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Reviewed-by: Bob Copeland <me@bobcopeland.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
drivers/net/wireless/ath/ath5k/base.c

index e9ea38d0fff604359728103ad9051c5ba3e662a8..b346d0492001f55ded8e3ccf8fbfcdfcc2cbabbd 100644 (file)
@@ -921,12 +921,6 @@ ath5k_txq_setup(struct ath5k_hw *ah,
                 */
                return ERR_PTR(qnum);
        }
-       if (qnum >= ARRAY_SIZE(ah->txqs)) {
-               ATH5K_ERR(ah, "hw qnum %u out of range, max %tu!\n",
-                       qnum, ARRAY_SIZE(ah->txqs));
-               ath5k_hw_release_tx_queue(ah, qnum);
-               return ERR_PTR(-EINVAL);
-       }
        txq = &ah->txqs[qnum];
        if (!txq->setup) {
                txq->qnum = qnum;