1. 01 2月, 2011 3 次提交
    • H
      rt2x00: Convert rt2800pci to use tasklets · a9d61e9e
      Helmut Schaa 提交于
      Fix interrupt processing on slow machines by using individual tasklets
      for each different device interrupt. This ensures that while a RX or TX
      status tasklet is scheduled only the according device interrupt is
      masked and other interrupts such as TBTT can still be processed.
      
      Also, this allows us to use tasklet_hi_schedule for TBTT and PRETBTT
      processing which is required to not send out beacons with a wrong DTIM
      count (due to delayed periodic beacon updates). Furthermore, this
      improves the latency between the TBTT and sending out buffered multi-
      and broadcast traffic.
      
      As a nice bonus, the interrupt handling overhead is reduced such that
      rt2800pci gains around 25% more throuhput on a rt3052 MIPS board.
      Signed-off-by: NHelmut Schaa <helmut.schaa@googlemail.com>
      Acked-by: NGertjan van Wingerde <gwingerde@gmail.com>
      Signed-off-by: NIvo van Doorn <IvDoorn@gmail.com>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      a9d61e9e
    • H
      rt2x00: Disable txstatus tasklet by default · c8e15a1e
      Helmut Schaa 提交于
      Enable the txstatus tasklet when interrupts are enabled and disable it
      together with the interrupts. Also make the txstatus tasklet useful even
      without the tx status FIFO and make use of the generic rt2x00 tasklet
      initialization macro.
      Signed-off-by: NHelmut Schaa <helmut.schaa@googlemail.com>
      Acked-by: NGertjan van Wingerde <gwingerde@gmail.com>
      Signed-off-by: NIvo van Doorn <IvDoorn@gmail.com>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      c8e15a1e
    • H
      rt2x00: Refactor beacon code to make use of start- and stop_queue · 69cf36a4
      Helmut Schaa 提交于
      This patch allows to dynamically remove beaconing interfaces without
      shutting beaconing down on all interfaces.
      
      The only place to start and stop beaconing are now the start- and
      stop_queue callbacks. Hence, we can remove some register writes during
      interface bring up (config_intf) and only write the correct sync mode
      to the register there.
      
      When multiple beaconing interfaces are present we should enable
      beaconing as soon as mac80211 enables beaconing on at least one of
      them. The beacon queue gets stopped when the last beaconing
      interface was stopped by mac80211. Therefore, introduce another
      interface counter to keep track ot the number of enabled beaconing
      interfaces and start or stop the beacon queue accordingly.
      
      To allow single interfaces to stop beaconing, add a new driver
      callback clear_beacon to clear a single interface's beacon without
      affecting the other interfaces. Don't overload the clear_entry callback
      for clearing beacons as that would introduce additional overhead
      (check for each TX queue) into the clear_entry callback which is used
      on the drivers TX/RX hotpaths.
      
      Furthermore, the write beacon callback doesn't need to enable beaconing
      anymore but since beaconing should be disabled while a new beacon is
      written or cleared we still disable beacon generation and enable it
      afterwards again in the driver specific callbacks. However, beacon
      related interrupts should not be disabled/enabled here, that's solely
      done from the start- and stop queue callbacks. It would be nice to stop
      the beacon queue just before the beacon update and enable it afterwards
      in rt2x00queue itself instead of the current implementation that relies
      on the driver doing the right thing. However, since start- and
      stop_queue are mutex protected we cannot use them for atomic beacon
      updates.
      Signed-off-by: NHelmut Schaa <helmut.schaa@googlemail.com>
      Acked-by: NGertjan van Wingerde <gwingerde@gmail.com>
      Signed-off-by: NIvo van Doorn <IvDoorn@gmail.com>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      69cf36a4
  2. 20 1月, 2011 1 次提交
  3. 05 1月, 2011 1 次提交
  4. 21 12月, 2010 1 次提交
  5. 14 12月, 2010 6 次提交
  6. 01 12月, 2010 1 次提交
  7. 18 11月, 2010 4 次提交
  8. 16 11月, 2010 4 次提交
  9. 12 10月, 2010 2 次提交
  10. 06 10月, 2010 2 次提交
    • H
      rt2x00: Fix race between dma mapping and clearing rx entries in rt2800pci · 95192339
      Helmut Schaa 提交于
      During rx, rt2x00lib calls rt2800pci_fill_rxdone to read the RX
      descriptor. At that time the skb is already dma unmapped but no new skb
      was dma mapped for this entry again. However, rt2800pci_fill_rxdone also
      moves the hw rx queue index, marking this entry to be available for
      reuse. Since no new skb was dma mapped and also the previous skb was
      unmapped this might lead to strange hw behavior.
      
      To fix this issue move the hw rx queue index increment to
      rt2800pci_clear_entry where a new skb was already dma mapped and can be
      safely used by the hw.
      Signed-off-by: NHelmut Schaa <helmut.schaa@googlemail.com>
      Signed-off-by: NIvo van Doorn <IvDoorn@gmail.com>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      95192339
    • H
      rt2x00: rework tx status handling in rt2800pci · 96c3da7d
      Helmut Schaa 提交于
      This patch changes the way tx status reports are handled by rt2800pci.
      Previously rt2800pci would sometimes lose tx status reports as the
      TX_STA_FIFO register is a fifo of 16 entries that can overflow in case
      we don't read it often/fast enough. Since interrupts are disabled in the
      device during the execution of the interrupt thread it happend sometimes
      under high network and CPU load that processing took too long and a few
      tx status reports were dropped by the hw.
      
      To fix this issue the TX_STA_FIFO register is read directly in the
      interrupt handler and stored in a kfifo which is large enough to hold
      all status reports of all used tx queues.
      
      To process the status reports a new tasklet txstatus_tasklet is used.
      Using the already used interrupt thread is not possible since we don't
      want to disable the TX_FIFO_STATUS interrupt while processing them and
      it is not possible to schedule the interrupt thread multiple times for
      execution. A tasklet instead can be scheduled multiple times which
      allows to leave the TX_FIFO_STATUS interrupt enabled while a previously
      scheduled tasklet is still executing.
      
      In short: All other interrupts are handled in the interrupt thread as
      before. Only the TX_FIFO_STATUS interrupt is partly handled in the
      interrupt handler and finished in the according tasklet.
      
      One drawback of this patch is that it duplicates some code from
      rt2800lib. However, that can be cleaned up in the future once the
      rt2800usb and rt2800pci tx status handling converge more.
      
      Using this patch on a Ralink RT3052 embedded board gives me a reliable
      wireless connection even under high CPU and network load. I've
      transferred several gigabytes without any queue lockups.
      Signed-off-by: NHelmut Schaa <helmut.schaa@googlemail.com>
      Signed-off-by: NIvo van Doorn <IvDoorn@gmail.com>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      96c3da7d
  11. 15 9月, 2010 1 次提交
  12. 01 9月, 2010 1 次提交
  13. 26 8月, 2010 3 次提交
  14. 17 8月, 2010 2 次提交
  15. 13 7月, 2010 8 次提交