diff options
-rw-r--r-- | drivers/net/wireless/bcm43xx/bcm43xx_dma.c | 61 | ||||
-rw-r--r-- | drivers/net/wireless/bcm43xx/bcm43xx_dma.h | 18 |
2 files changed, 51 insertions, 28 deletions
diff --git a/drivers/net/wireless/bcm43xx/bcm43xx_dma.c b/drivers/net/wireless/bcm43xx/bcm43xx_dma.c index 0cd292847954..fbe19b922aa7 100644 --- a/drivers/net/wireless/bcm43xx/bcm43xx_dma.c +++ b/drivers/net/wireless/bcm43xx/bcm43xx_dma.c | |||
@@ -374,13 +374,11 @@ static int dmacontroller_setup(struct bcm43xx_dmaring *ring) | |||
374 | 374 | ||
375 | if (ring->tx) { | 375 | if (ring->tx) { |
376 | /* Set Transmit Control register to "transmit enable" */ | 376 | /* Set Transmit Control register to "transmit enable" */ |
377 | bcm43xx_write32(ring->bcm, | 377 | bcm43xx_dma_write(ring, BCM43xx_DMA_TX_CONTROL, |
378 | ring->mmio_base + BCM43xx_DMA_TX_CONTROL, | 378 | BCM43xx_DMA_TXCTRL_ENABLE); |
379 | BCM43xx_DMA_TXCTRL_ENABLE); | ||
380 | /* Set Transmit Descriptor ring address. */ | 379 | /* Set Transmit Descriptor ring address. */ |
381 | bcm43xx_write32(ring->bcm, | 380 | bcm43xx_dma_write(ring, BCM43xx_DMA_TX_DESC_RING, |
382 | ring->mmio_base + BCM43xx_DMA_TX_DESC_RING, | 381 | ring->dmabase + ring->memoffset); |
383 | ring->dmabase + ring->memoffset); | ||
384 | } else { | 382 | } else { |
385 | err = alloc_initial_descbuffers(ring); | 383 | err = alloc_initial_descbuffers(ring); |
386 | if (err) | 384 | if (err) |
@@ -388,17 +386,12 @@ static int dmacontroller_setup(struct bcm43xx_dmaring *ring) | |||
388 | /* Set Receive Control "receive enable" and frame offset */ | 386 | /* Set Receive Control "receive enable" and frame offset */ |
389 | value = (ring->frameoffset << BCM43xx_DMA_RXCTRL_FRAMEOFF_SHIFT); | 387 | value = (ring->frameoffset << BCM43xx_DMA_RXCTRL_FRAMEOFF_SHIFT); |
390 | value |= BCM43xx_DMA_RXCTRL_ENABLE; | 388 | value |= BCM43xx_DMA_RXCTRL_ENABLE; |
391 | bcm43xx_write32(ring->bcm, | 389 | bcm43xx_dma_write(ring, BCM43xx_DMA_RX_CONTROL, value); |
392 | ring->mmio_base + BCM43xx_DMA_RX_CONTROL, | ||
393 | value); | ||
394 | /* Set Receive Descriptor ring address. */ | 390 | /* Set Receive Descriptor ring address. */ |
395 | bcm43xx_write32(ring->bcm, | 391 | bcm43xx_dma_write(ring, BCM43xx_DMA_RX_DESC_RING, |
396 | ring->mmio_base + BCM43xx_DMA_RX_DESC_RING, | 392 | ring->dmabase + ring->memoffset); |
397 | ring->dmabase + ring->memoffset); | ||
398 | /* Init the descriptor pointer. */ | 393 | /* Init the descriptor pointer. */ |
399 | bcm43xx_write32(ring->bcm, | 394 | bcm43xx_dma_write(ring, BCM43xx_DMA_RX_DESC_INDEX, 200); |
400 | ring->mmio_base + BCM43xx_DMA_RX_DESC_INDEX, | ||
401 | 200); | ||
402 | } | 395 | } |
403 | 396 | ||
404 | out: | 397 | out: |
@@ -411,15 +404,11 @@ static void dmacontroller_cleanup(struct bcm43xx_dmaring *ring) | |||
411 | if (ring->tx) { | 404 | if (ring->tx) { |
412 | bcm43xx_dmacontroller_tx_reset(ring->bcm, ring->mmio_base); | 405 | bcm43xx_dmacontroller_tx_reset(ring->bcm, ring->mmio_base); |
413 | /* Zero out Transmit Descriptor ring address. */ | 406 | /* Zero out Transmit Descriptor ring address. */ |
414 | bcm43xx_write32(ring->bcm, | 407 | bcm43xx_dma_write(ring, BCM43xx_DMA_TX_DESC_RING, 0); |
415 | ring->mmio_base + BCM43xx_DMA_TX_DESC_RING, | ||
416 | 0x00000000); | ||
417 | } else { | 408 | } else { |
418 | bcm43xx_dmacontroller_rx_reset(ring->bcm, ring->mmio_base); | 409 | bcm43xx_dmacontroller_rx_reset(ring->bcm, ring->mmio_base); |
419 | /* Zero out Receive Descriptor ring address. */ | 410 | /* Zero out Receive Descriptor ring address. */ |
420 | bcm43xx_write32(ring->bcm, | 411 | bcm43xx_dma_write(ring, BCM43xx_DMA_RX_DESC_RING, 0); |
421 | ring->mmio_base + BCM43xx_DMA_RX_DESC_RING, | ||
422 | 0x00000000); | ||
423 | } | 412 | } |
424 | } | 413 | } |
425 | 414 | ||
@@ -698,9 +687,8 @@ static void dmacontroller_poke_tx(struct bcm43xx_dmaring *ring, | |||
698 | */ | 687 | */ |
699 | wmb(); | 688 | wmb(); |
700 | slot = next_slot(ring, slot); | 689 | slot = next_slot(ring, slot); |
701 | bcm43xx_write32(ring->bcm, | 690 | bcm43xx_dma_write(ring, BCM43xx_DMA_TX_DESC_INDEX, |
702 | ring->mmio_base + BCM43xx_DMA_TX_DESC_INDEX, | 691 | (u32)(slot * sizeof(struct bcm43xx_dmadesc))); |
703 | (u32)(slot * sizeof(struct bcm43xx_dmadesc))); | ||
704 | } | 692 | } |
705 | 693 | ||
706 | static int dma_tx_fragment(struct bcm43xx_dmaring *ring, | 694 | static int dma_tx_fragment(struct bcm43xx_dmaring *ring, |
@@ -940,7 +928,7 @@ void bcm43xx_dma_rx(struct bcm43xx_dmaring *ring) | |||
940 | #endif | 928 | #endif |
941 | 929 | ||
942 | assert(!ring->tx); | 930 | assert(!ring->tx); |
943 | status = bcm43xx_read32(ring->bcm, ring->mmio_base + BCM43xx_DMA_RX_STATUS); | 931 | status = bcm43xx_dma_read(ring, BCM43xx_DMA_RX_STATUS); |
944 | descptr = (status & BCM43xx_DMA_RXSTAT_DPTR_MASK); | 932 | descptr = (status & BCM43xx_DMA_RXSTAT_DPTR_MASK); |
945 | current_slot = descptr / sizeof(struct bcm43xx_dmadesc); | 933 | current_slot = descptr / sizeof(struct bcm43xx_dmadesc); |
946 | assert(current_slot >= 0 && current_slot < ring->nr_slots); | 934 | assert(current_slot >= 0 && current_slot < ring->nr_slots); |
@@ -953,10 +941,27 @@ void bcm43xx_dma_rx(struct bcm43xx_dmaring *ring) | |||
953 | ring->max_used_slots = used_slots; | 941 | ring->max_used_slots = used_slots; |
954 | #endif | 942 | #endif |
955 | } | 943 | } |
956 | bcm43xx_write32(ring->bcm, | 944 | bcm43xx_dma_write(ring, BCM43xx_DMA_RX_DESC_INDEX, |
957 | ring->mmio_base + BCM43xx_DMA_RX_DESC_INDEX, | 945 | (u32)(slot * sizeof(struct bcm43xx_dmadesc))); |
958 | (u32)(slot * sizeof(struct bcm43xx_dmadesc))); | ||
959 | ring->current_slot = slot; | 946 | ring->current_slot = slot; |
960 | } | 947 | } |
961 | 948 | ||
949 | void bcm43xx_dma_tx_suspend(struct bcm43xx_dmaring *ring) | ||
950 | { | ||
951 | assert(ring->tx); | ||
952 | bcm43xx_power_saving_ctl_bits(ring->bcm, -1, 1); | ||
953 | bcm43xx_dma_write(ring, BCM43xx_DMA_TX_CONTROL, | ||
954 | bcm43xx_dma_read(ring, BCM43xx_DMA_TX_CONTROL) | ||
955 | | BCM43xx_DMA_TXCTRL_SUSPEND); | ||
956 | } | ||
957 | |||
958 | void bcm43xx_dma_tx_resume(struct bcm43xx_dmaring *ring) | ||
959 | { | ||
960 | assert(ring->tx); | ||
961 | bcm43xx_dma_write(ring, BCM43xx_DMA_TX_CONTROL, | ||
962 | bcm43xx_dma_read(ring, BCM43xx_DMA_TX_CONTROL) | ||
963 | & ~BCM43xx_DMA_TXCTRL_SUSPEND); | ||
964 | bcm43xx_power_saving_ctl_bits(ring->bcm, -1, -1); | ||
965 | } | ||
966 | |||
962 | /* vim: set ts=8 sw=8 sts=8: */ | 967 | /* vim: set ts=8 sw=8 sts=8: */ |
diff --git a/drivers/net/wireless/bcm43xx/bcm43xx_dma.h b/drivers/net/wireless/bcm43xx/bcm43xx_dma.h index c07e34689be1..2d520e4b0276 100644 --- a/drivers/net/wireless/bcm43xx/bcm43xx_dma.h +++ b/drivers/net/wireless/bcm43xx/bcm43xx_dma.h | |||
@@ -140,6 +140,21 @@ struct bcm43xx_dmaring { | |||
140 | }; | 140 | }; |
141 | 141 | ||
142 | 142 | ||
143 | static inline | ||
144 | u32 bcm43xx_dma_read(struct bcm43xx_dmaring *ring, | ||
145 | u16 offset) | ||
146 | { | ||
147 | return bcm43xx_read32(ring->bcm, ring->mmio_base + offset); | ||
148 | } | ||
149 | |||
150 | static inline | ||
151 | void bcm43xx_dma_write(struct bcm43xx_dmaring *ring, | ||
152 | u16 offset, u32 value) | ||
153 | { | ||
154 | bcm43xx_write32(ring->bcm, ring->mmio_base + offset, value); | ||
155 | } | ||
156 | |||
157 | |||
143 | int bcm43xx_dma_init(struct bcm43xx_private *bcm); | 158 | int bcm43xx_dma_init(struct bcm43xx_private *bcm); |
144 | void bcm43xx_dma_free(struct bcm43xx_private *bcm); | 159 | void bcm43xx_dma_free(struct bcm43xx_private *bcm); |
145 | 160 | ||
@@ -148,6 +163,9 @@ int bcm43xx_dmacontroller_rx_reset(struct bcm43xx_private *bcm, | |||
148 | int bcm43xx_dmacontroller_tx_reset(struct bcm43xx_private *bcm, | 163 | int bcm43xx_dmacontroller_tx_reset(struct bcm43xx_private *bcm, |
149 | u16 dmacontroller_mmio_base); | 164 | u16 dmacontroller_mmio_base); |
150 | 165 | ||
166 | void bcm43xx_dma_tx_suspend(struct bcm43xx_dmaring *ring); | ||
167 | void bcm43xx_dma_tx_resume(struct bcm43xx_dmaring *ring); | ||
168 | |||
151 | void bcm43xx_dma_handle_xmitstatus(struct bcm43xx_private *bcm, | 169 | void bcm43xx_dma_handle_xmitstatus(struct bcm43xx_private *bcm, |
152 | struct bcm43xx_xmitstatus *status); | 170 | struct bcm43xx_xmitstatus *status); |
153 | 171 | ||