1. 05 4月, 2011 1 次提交
  2. 05 3月, 2011 7 次提交
  3. 01 2月, 2011 3 次提交
    • H
      rt2x00: Remove STATE_RADIO_IRQ_OFF_ISR and STATE_RADIO_IRQ_ON_ISR · b550911a
      Helmut Schaa 提交于
      Remove STATE_RADIO_IRQ_OFF_ISR and STATE_RADIO_IRQ_ON_ISR as they are
      not used anymore.
      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>
      b550911a
    • H
      rt2x00: Convert rt2500pci interrupt handling to use tasklets · 16222a0d
      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 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 should be much lower.
      
      Compile-tested only.
      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>
      16222a0d
    • 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
  4. 14 12月, 2010 4 次提交
  5. 16 11月, 2010 4 次提交
  6. 12 10月, 2010 1 次提交
  7. 15 9月, 2010 1 次提交
  8. 26 8月, 2010 2 次提交
  9. 18 8月, 2010 1 次提交
  10. 13 7月, 2010 5 次提交
  11. 01 7月, 2010 2 次提交
  12. 03 6月, 2010 2 次提交
  13. 25 5月, 2010 1 次提交
  14. 13 5月, 2010 2 次提交
  15. 11 5月, 2010 2 次提交
  16. 05 5月, 2010 1 次提交
  17. 07 4月, 2010 1 次提交