1. 06 12月, 2006 1 次提交
    • D
      [PATCH] zd1211rw: zd_mac_rx isn't always called in IRQ context · 383956a9
      Daniel Drake 提交于
      e.g.
      
      usb 1-7: rx_urb_complete() *** first fragment ***
      usb 1-7: rx_urb_complete() *** second fragment ***
      drivers/net/wireless/zd1211rw/zd_mac.c:1063 ASSERT
      (((current_thread_info()->preempt_count) & (((1UL << (12))-1) << ((0 +
      8) + 8)))) VIOLATED!
       [<f0299448>] zd_mac_rx+0x3e7/0x47a [zd1211rw]
       [<f029badc>] rx_urb_complete+0x22d/0x24a [zd1211rw]
       [<b028a22f>] urb_destroy+0x0/0x5
       [<b01f0930>] kref_put+0x65/0x72
       [<b0288cdf>] usb_hcd_giveback_urb+0x28/0x57
       [<b02950c4>] qh_completions+0x296/0x2f6
       [<b0294b21>] ehci_urb_done+0x70/0x7a
       [<b0294ea1>] qh_completions+0x73/0x2f6
       [<b02951bc>] ehci_work+0x98/0x538
      
      Remove the bogus assertion, and use dev_kfree_skb_any as pointed out by
      Ulrich Kunitz.
      Signed-off-by: NDaniel Drake <dsd@gentoo.org>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      383956a9
  2. 02 12月, 2006 28 次提交
  3. 30 11月, 2006 1 次提交
  4. 29 11月, 2006 2 次提交
  5. 08 11月, 2006 2 次提交
  6. 01 11月, 2006 3 次提交
    • L
      [PATCH] bcm43xx: fix unexpected LED control values in BCM4303 sprom · df6d7c94
      Larry Finger 提交于
      The bcm43xx driver uses 4 locations in the devices sprom to determine
      the behavior of the leds. Certain defaults are assigned if all bits are
      set in those locations. On at least one BCM4303 chip, the sprom contains
      values other than the default, which executes an assertion placed in the
      default case of a following switch statement. This patch makes the leds
      on the above mentioned interface behave correctly. In addition, it limits
      the number of logged messages to 20 for the case of unexpected values in
      the sprom locations.
      Signed-off-by: NLarry Finger <Larry.Finger@lwfinger.net>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      df6d7c94
    • M
      [PATCH] bcm43xx: Fix low-traffic netdev watchdog TX timeouts · 81e171b9
      Michael Buesch 提交于
      This fixes a netdev watchdog timeout problem.
      The software needs to call netif_tx_disable before running the
      hardware calibration code. The problem condition can be shown by the
      following timegraph.
      
      |---5secs - ~10 jiffies time---|---|OOPS
      ^                              ^
      last real TX                   periodic work stops netif
      
      At OOPS, the following happens:
      The watchdog timer triggers, because the timeout of 5secs
      is over. The watchdog first checks for stopped TX.
      _Usually_ TX is only stopped from the TX handler to indicate
      a full TX queue. But this is different. We need to stop TX here,
      regardless of the TX queue state. So the watchdog recognizes
      the stopped device and assumes it is stopped due to full
      TX queues (Which is a _wrong_ assumption in this case). It then
      tests how far the last TX has been in the past. If it's more than
      5secs (which is the case for low or no traffic), it will fire
      a TX timeout.
      Signed-off-by: NMichael Buesch <mb@bu3sch.de>
      Signed-off-by: NLarry Finger <Larry.Finger@lwfinger.net>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      81e171b9
    • P
      [PATCH] hostap_plx: fix CIS verification · 115e222d
      Pavel Roskin 提交于
      The length of the manfid CIS should be at least 4, and it's normally 4.
      It's incorrect to require it to be at least 5.  This breaks support for
      most (if not all) cards.
      
      The right place to ensure that we don't access beyond the CIS buffer is
      to strengthen another check.  Make sure that the next tuple begins at
      least at the CIS buffer end (in which case we stop processing) or
      before that.
      
      Reported by ph35sm@free.fr
      Signed-off-by: NPavel Roskin <proski@gnu.org>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      115e222d
  7. 26 10月, 2006 1 次提交
  8. 25 10月, 2006 1 次提交
  9. 18 10月, 2006 1 次提交