diff options
author | Sujith <Sujith.Manoharan@atheros.com> | 2009-03-30 05:58:45 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-04-22 16:54:35 -0400 |
commit | 797fe5cbefdb91f796502677e3a6623262eb9fcd (patch) | |
tree | 8d9931b9853a0c5d5f516d2c10bf07d24dedb749 /drivers/net/wireless | |
parent | 4658b985170d9d0c88304d2d4459938b600f8c0b (diff) |
ath9k: Remove the useless do..while loops
These are unnecessary constructs in a function.
This patch removes these from both RX and TX init
routines.
Signed-off-by: Sujith <Sujith.Manoharan@atheros.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless')
-rw-r--r-- | drivers/net/wireless/ath9k/ath9k.h | 2 | ||||
-rw-r--r-- | drivers/net/wireless/ath9k/recv.c | 83 | ||||
-rw-r--r-- | drivers/net/wireless/ath9k/xmit.c | 40 |
3 files changed, 57 insertions, 68 deletions
diff --git a/drivers/net/wireless/ath9k/ath9k.h b/drivers/net/wireless/ath9k/ath9k.h index 0ef89bb73f31..c92d46fa9d51 100644 --- a/drivers/net/wireless/ath9k/ath9k.h +++ b/drivers/net/wireless/ath9k/ath9k.h | |||
@@ -340,7 +340,7 @@ void ath_tx_node_init(struct ath_softc *sc, struct ath_node *an); | |||
340 | void ath_tx_node_cleanup(struct ath_softc *sc, struct ath_node *an); | 340 | void ath_tx_node_cleanup(struct ath_softc *sc, struct ath_node *an); |
341 | void ath_txq_schedule(struct ath_softc *sc, struct ath_txq *txq); | 341 | void ath_txq_schedule(struct ath_softc *sc, struct ath_txq *txq); |
342 | int ath_tx_init(struct ath_softc *sc, int nbufs); | 342 | int ath_tx_init(struct ath_softc *sc, int nbufs); |
343 | int ath_tx_cleanup(struct ath_softc *sc); | 343 | void ath_tx_cleanup(struct ath_softc *sc); |
344 | struct ath_txq *ath_test_get_txq(struct ath_softc *sc, struct sk_buff *skb); | 344 | struct ath_txq *ath_test_get_txq(struct ath_softc *sc, struct sk_buff *skb); |
345 | int ath_txq_update(struct ath_softc *sc, int qnum, | 345 | int ath_txq_update(struct ath_softc *sc, int qnum, |
346 | struct ath9k_tx_queue_info *q); | 346 | struct ath9k_tx_queue_info *q); |
diff --git a/drivers/net/wireless/ath9k/recv.c b/drivers/net/wireless/ath9k/recv.c index efa57ae8901c..b46badd21f73 100644 --- a/drivers/net/wireless/ath9k/recv.c +++ b/drivers/net/wireless/ath9k/recv.c | |||
@@ -283,54 +283,51 @@ int ath_rx_init(struct ath_softc *sc, int nbufs) | |||
283 | struct ath_buf *bf; | 283 | struct ath_buf *bf; |
284 | int error = 0; | 284 | int error = 0; |
285 | 285 | ||
286 | do { | 286 | spin_lock_init(&sc->rx.rxflushlock); |
287 | spin_lock_init(&sc->rx.rxflushlock); | 287 | sc->sc_flags &= ~SC_OP_RXFLUSH; |
288 | sc->sc_flags &= ~SC_OP_RXFLUSH; | 288 | spin_lock_init(&sc->rx.rxbuflock); |
289 | spin_lock_init(&sc->rx.rxbuflock); | ||
290 | |||
291 | sc->rx.bufsize = roundup(IEEE80211_MAX_MPDU_LEN, | ||
292 | min(sc->cachelsz, | ||
293 | (u16)64)); | ||
294 | 289 | ||
295 | DPRINTF(sc, ATH_DBG_CONFIG, "cachelsz %u rxbufsize %u\n", | 290 | sc->rx.bufsize = roundup(IEEE80211_MAX_MPDU_LEN, |
296 | sc->cachelsz, sc->rx.bufsize); | 291 | min(sc->cachelsz, (u16)64)); |
297 | 292 | ||
298 | /* Initialize rx descriptors */ | 293 | DPRINTF(sc, ATH_DBG_CONFIG, "cachelsz %u rxbufsize %u\n", |
294 | sc->cachelsz, sc->rx.bufsize); | ||
299 | 295 | ||
300 | error = ath_descdma_setup(sc, &sc->rx.rxdma, &sc->rx.rxbuf, | 296 | /* Initialize rx descriptors */ |
301 | "rx", nbufs, 1); | ||
302 | if (error != 0) { | ||
303 | DPRINTF(sc, ATH_DBG_FATAL, | ||
304 | "failed to allocate rx descriptors: %d\n", error); | ||
305 | break; | ||
306 | } | ||
307 | 297 | ||
308 | list_for_each_entry(bf, &sc->rx.rxbuf, list) { | 298 | error = ath_descdma_setup(sc, &sc->rx.rxdma, &sc->rx.rxbuf, |
309 | skb = ath_rxbuf_alloc(sc, sc->rx.bufsize, GFP_KERNEL); | 299 | "rx", nbufs, 1); |
310 | if (skb == NULL) { | 300 | if (error != 0) { |
311 | error = -ENOMEM; | 301 | DPRINTF(sc, ATH_DBG_FATAL, |
312 | break; | 302 | "failed to allocate rx descriptors: %d\n", error); |
313 | } | 303 | goto err; |
304 | } | ||
314 | 305 | ||
315 | bf->bf_mpdu = skb; | 306 | list_for_each_entry(bf, &sc->rx.rxbuf, list) { |
316 | bf->bf_buf_addr = dma_map_single(sc->dev, skb->data, | 307 | skb = ath_rxbuf_alloc(sc, sc->rx.bufsize, GFP_KERNEL); |
317 | sc->rx.bufsize, | 308 | if (skb == NULL) { |
318 | DMA_FROM_DEVICE); | 309 | error = -ENOMEM; |
319 | if (unlikely(dma_mapping_error(sc->dev, | 310 | goto err; |
320 | bf->bf_buf_addr))) { | ||
321 | dev_kfree_skb_any(skb); | ||
322 | bf->bf_mpdu = NULL; | ||
323 | DPRINTF(sc, ATH_DBG_FATAL, | ||
324 | "dma_mapping_error() on RX init\n"); | ||
325 | error = -ENOMEM; | ||
326 | break; | ||
327 | } | ||
328 | bf->bf_dmacontext = bf->bf_buf_addr; | ||
329 | } | 311 | } |
330 | sc->rx.rxlink = NULL; | ||
331 | 312 | ||
332 | } while (0); | 313 | bf->bf_mpdu = skb; |
314 | bf->bf_buf_addr = dma_map_single(sc->dev, skb->data, | ||
315 | sc->rx.bufsize, | ||
316 | DMA_FROM_DEVICE); | ||
317 | if (unlikely(dma_mapping_error(sc->dev, | ||
318 | bf->bf_buf_addr))) { | ||
319 | dev_kfree_skb_any(skb); | ||
320 | bf->bf_mpdu = NULL; | ||
321 | DPRINTF(sc, ATH_DBG_FATAL, | ||
322 | "dma_mapping_error() on RX init\n"); | ||
323 | error = -ENOMEM; | ||
324 | goto err; | ||
325 | } | ||
326 | bf->bf_dmacontext = bf->bf_buf_addr; | ||
327 | } | ||
328 | sc->rx.rxlink = NULL; | ||
333 | 329 | ||
330 | err: | ||
334 | if (error) | 331 | if (error) |
335 | ath_rx_cleanup(sc); | 332 | ath_rx_cleanup(sc); |
336 | 333 | ||
@@ -345,10 +342,8 @@ void ath_rx_cleanup(struct ath_softc *sc) | |||
345 | list_for_each_entry(bf, &sc->rx.rxbuf, list) { | 342 | list_for_each_entry(bf, &sc->rx.rxbuf, list) { |
346 | skb = bf->bf_mpdu; | 343 | skb = bf->bf_mpdu; |
347 | if (skb) { | 344 | if (skb) { |
348 | dma_unmap_single(sc->dev, | 345 | dma_unmap_single(sc->dev, bf->bf_buf_addr, |
349 | bf->bf_buf_addr, | 346 | sc->rx.bufsize, DMA_FROM_DEVICE); |
350 | sc->rx.bufsize, | ||
351 | DMA_FROM_DEVICE); | ||
352 | dev_kfree_skb(skb); | 347 | dev_kfree_skb(skb); |
353 | } | 348 | } |
354 | } | 349 | } |
diff --git a/drivers/net/wireless/ath9k/xmit.c b/drivers/net/wireless/ath9k/xmit.c index 735256faa0b2..628b780d8844 100644 --- a/drivers/net/wireless/ath9k/xmit.c +++ b/drivers/net/wireless/ath9k/xmit.c | |||
@@ -2047,44 +2047,38 @@ int ath_tx_init(struct ath_softc *sc, int nbufs) | |||
2047 | { | 2047 | { |
2048 | int error = 0; | 2048 | int error = 0; |
2049 | 2049 | ||
2050 | do { | 2050 | spin_lock_init(&sc->tx.txbuflock); |
2051 | spin_lock_init(&sc->tx.txbuflock); | ||
2052 | 2051 | ||
2053 | error = ath_descdma_setup(sc, &sc->tx.txdma, &sc->tx.txbuf, | 2052 | error = ath_descdma_setup(sc, &sc->tx.txdma, &sc->tx.txbuf, |
2054 | "tx", nbufs, 1); | 2053 | "tx", nbufs, 1); |
2055 | if (error != 0) { | 2054 | if (error != 0) { |
2056 | DPRINTF(sc, ATH_DBG_FATAL, | 2055 | DPRINTF(sc, ATH_DBG_FATAL, |
2057 | "Failed to allocate tx descriptors: %d\n", | 2056 | "Failed to allocate tx descriptors: %d\n", error); |
2058 | error); | 2057 | goto err; |
2059 | break; | 2058 | } |
2060 | } | ||
2061 | |||
2062 | error = ath_descdma_setup(sc, &sc->beacon.bdma, &sc->beacon.bbuf, | ||
2063 | "beacon", ATH_BCBUF, 1); | ||
2064 | if (error != 0) { | ||
2065 | DPRINTF(sc, ATH_DBG_FATAL, | ||
2066 | "Failed to allocate beacon descriptors: %d\n", | ||
2067 | error); | ||
2068 | break; | ||
2069 | } | ||
2070 | 2059 | ||
2071 | } while (0); | 2060 | error = ath_descdma_setup(sc, &sc->beacon.bdma, &sc->beacon.bbuf, |
2061 | "beacon", ATH_BCBUF, 1); | ||
2062 | if (error != 0) { | ||
2063 | DPRINTF(sc, ATH_DBG_FATAL, | ||
2064 | "Failed to allocate beacon descriptors: %d\n", error); | ||
2065 | goto err; | ||
2066 | } | ||
2072 | 2067 | ||
2068 | err: | ||
2073 | if (error != 0) | 2069 | if (error != 0) |
2074 | ath_tx_cleanup(sc); | 2070 | ath_tx_cleanup(sc); |
2075 | 2071 | ||
2076 | return error; | 2072 | return error; |
2077 | } | 2073 | } |
2078 | 2074 | ||
2079 | int ath_tx_cleanup(struct ath_softc *sc) | 2075 | void ath_tx_cleanup(struct ath_softc *sc) |
2080 | { | 2076 | { |
2081 | if (sc->beacon.bdma.dd_desc_len != 0) | 2077 | if (sc->beacon.bdma.dd_desc_len != 0) |
2082 | ath_descdma_cleanup(sc, &sc->beacon.bdma, &sc->beacon.bbuf); | 2078 | ath_descdma_cleanup(sc, &sc->beacon.bdma, &sc->beacon.bbuf); |
2083 | 2079 | ||
2084 | if (sc->tx.txdma.dd_desc_len != 0) | 2080 | if (sc->tx.txdma.dd_desc_len != 0) |
2085 | ath_descdma_cleanup(sc, &sc->tx.txdma, &sc->tx.txbuf); | 2081 | ath_descdma_cleanup(sc, &sc->tx.txdma, &sc->tx.txbuf); |
2086 | |||
2087 | return 0; | ||
2088 | } | 2082 | } |
2089 | 2083 | ||
2090 | void ath_tx_node_init(struct ath_softc *sc, struct ath_node *an) | 2084 | void ath_tx_node_init(struct ath_softc *sc, struct ath_node *an) |