1. 28 2月, 2009 3 次提交
    • M
      b43: Optimize DMA buffers · bdceeb2d
      Michael Buesch 提交于
      In the old days we used one slot per frame. But when we changed that to 2,
      we didn't raise the overall slot count. Which resulted in an effective
      division of two to the number of slots.
      
      Double the number of TX slots, so we have an effective hardware queue
      of 128 frames per QoS queue.
      
      Also optimize the TX header cache handling. We don't need a cached TX header
      for slots that will never carry an actual header.
      So we reduce the memory consumption of the cache by 50%.
      
      So as a net result we end up with more or less the same memory usage before
      and after this patch (except a few tiny meta structures), but have twice
      the number of TX slots available.
      Signed-off-by: NMichael Buesch <mb@bu3sch.de>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      bdceeb2d
    • M
      b43: Fix DMA buffer size handling · 8eccb53f
      Michael Buesch 提交于
      This fixes hidden bugs in the size handling of the DMA buffers.
      This sets the RX buffer size to the theoretical max packet size and
      fixes passing of the size values to the device (must not subtract the header offset).
      
      These bugs are hidden and don't actually trigger due to the magic +100
      offset for the buffer size.
      Signed-off-by: NMichael Buesch <mb@bu3sch.de>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      8eccb53f
    • M
      b43: Move DMA stop sanity check · ca2d559e
      Michael Buesch 提交于
      Move the DMA stop sanity check up a few lines, so it's actually
      theoretically possible to trigger. (But it still shouldn't trigger, of course).
      Signed-off-by: NMichael Buesch <mb@bu3sch.de>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      ca2d559e
  2. 01 11月, 2008 1 次提交
  3. 27 6月, 2008 1 次提交
  4. 14 6月, 2008 1 次提交
  5. 22 5月, 2008 2 次提交
  6. 08 5月, 2008 1 次提交
  7. 24 4月, 2008 1 次提交
  8. 16 4月, 2008 1 次提交
    • M
      ssb: Fix usage of struct device used for DMAing · 4ac58469
      Michael Buesch 提交于
      This fixes DMA on architectures where DMA is nontrivial, like PPC64.
      We must use the host-device's (PCI) struct device for any DMA
      operation instead of the SSB device. For this we add a new
      struct device pointer to the SSB device structure that will always
      point to the right device for DMAing.
      
      Without this patch b43 and b44 drivers won't work on complex-DMA
      architectures, that for example need dev->archdata for DMA operations.
      Signed-off-by: NMichael Buesch <mb@bu3sch.de>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      4ac58469
  9. 09 4月, 2008 1 次提交
    • M
      b43: Add PIO support for PCMCIA devices · 5100d5ac
      Michael Buesch 提交于
      This adds PIO support back (D'oh!) for PCMCIA devices.
      This is a complete rewrite of the old PIO code. It does actually work
      and we get reasonable performance out of it on a modern machine.
      On a PowerBook G4 I get a few MBit for TX and a few more for RX.
      So it doesn't work as well as DMA (of course), but it's a _lot_ faster
      than the old PIO code (only got a few kBit with that).
      
      The limiting factor is the host CPU speed. So it will generate 100%
      CPU usage when the network interface is heavily loaded. A voluntary preemption
      point in the RX path makes sure Desktop Latency isn't hurt.
      
      PIO is needed for 16bit PCMCIA devices, as we really don't want to poke with
      the braindead DMA mechanisms on PCMCIA sockets. Additionally, not all
      PCMCIA sockets do actually support DMA in 16bit mode (mine doesn't).
      Signed-off-by: NMichael Buesch <mb@bu3sch.de>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      5100d5ac
  10. 02 4月, 2008 1 次提交
  11. 25 3月, 2008 2 次提交
  12. 08 3月, 2008 4 次提交
  13. 06 2月, 2008 1 次提交
  14. 01 2月, 2008 1 次提交
  15. 29 1月, 2008 4 次提交
  16. 11 10月, 2007 1 次提交