1. 28 9月, 2011 1 次提交
    • J
      ath6kl: fix TCP corruption · 00b1edf1
      Jouni Malinen 提交于
      Commit 94e532d1 ("ath6kl: Fix system freeze under heavy data load")
      aligns the skb data without checking if the skb is cloned. Because of
      this ath6kl can corrupt the local TCP stack information that can result
      in TCP retransmission failing and TCP connections stalling.
      
      To avoid the corruption we need to copy the skb. Now the alignment
      in ath6kl_htc_tx_buf_align() doesn't corrupt TCP packets anymore (and is
      not even used for the cloned skb's that got copied since the alignment
      of the data is handled at the copy time).
      Signed-off-by: NJouni Malinen <jouni@qca.qualcomm.com>
      Signed-off-by: NKalle Valo <kvalo@qca.qualcomm.com>
      00b1edf1
  2. 23 9月, 2011 1 次提交
    • K
      ath6kl: pass only unicast frames for aggregation · 5694f962
      Kalle Valo 提交于
      When pinging form ar6003 to the AP RTT was high even when power save was
      disabled:
      
      100 packets transmitted, 97 received, 3% packet loss, time 99125ms
      rtt min/avg/max/mdev = 1.875/46.733/795.506/139.181 ms
      
      After some investigation one reason for this was that received
      multicast traffic confused the aggrecation logic and caused 400 ms
      timeouts when receiving multicast frames from AP.
      
      A simple way to fix is to pass only unicast frames for aggregation. This
      improves RTT:
      
      100 packets transmitted, 99 received, 1% packet loss, time 99144ms
      rtt min/avg/max/mdev = 2.083/13.084/403.390/56.794 ms
      Signed-off-by: NKalle Valo <kvalo@qca.qualcomm.com>
      5694f962
  3. 31 8月, 2011 7 次提交
  4. 10 8月, 2011 3 次提交
    • K
      ath6kl: fix function name conflicts with ath9k · ad226ec2
      Kalle Valo 提交于
      Stephen reported that compilation fails if both ath6kl and ath9k are
      compiled in:
      
      drivers/net/wireless/ath/ath6kl/built-in.o: In function `htc_start':
      (.opd+0x600): multiple definition of `htc_start'
      drivers/net/wireless/ath/ath9k/built-in.o:(.opd+0x3e40): first defined here
      drivers/net/wireless/ath/ath6kl/built-in.o: In function `.htc_stop':
      (.text+0x7b40): multiple definition of `.htc_stop'
      drivers/net/wireless/ath/ath9k/built-in.o:(.text+0x67b34): first defined he=
      re
      drivers/net/wireless/ath/ath6kl/built-in.o: In function `.htc_start':
      (.text+0x7d18): multiple definition of `.htc_start'
      drivers/net/wireless/ath/ath9k/built-in.o:(.text+0x67ba0): first defined he=
      re
      drivers/net/wireless/ath/ath6kl/built-in.o: In function `htc_stop':
      (.opd+0x5e8): multiple definition of `htc_stop'
      drivers/net/wireless/ath/ath9k/built-in.o:(.opd+0x3e28): first defined here
      
      To fix this add ath6kl prefix to all public functions in htc.c.
      Reported-by: NStephen Rothwell <sfr@canb.auug.org.au>
      Signed-off-by: NKalle Valo <kvalo@qca.qualcomm.com>
      ad226ec2
    • K
      ath6kl: change aggreation timeout message from an error to a debug message · 37ca6335
      Kalle Valo 提交于
      When I connect to my Linksys WT610N AP supporting 11n I see a lot of
      aggreation timeout errors:
      
      [  408.885053] ath6kl: aggr timeout (st 3109 end 3140)
      [  463.872108] ath6kl: aggr timeout (st 3671 end 3702)
      [  495.010060] ath6kl: aggr timeout (st 3983 end 4014)
      [  503.604047] ath6kl: aggr timeout (st 4065 end 0)
      [  518.963047] ath6kl: aggr timeout (st 141 end 172)
      [  525.014066] ath6kl: aggr timeout (st 205 end 236)
      [  573.957051] ath6kl: aggr timeout (st 701 end 732)
      [  585.019067] ath6kl: aggr timeout (st 816 end 847)
      
      But still the connection seems to work. To not clutter the logs change
      the error message to a debug message. But add a fixme comment so that
      this will be investigated.
      Signed-off-by: NKalle Valo <kvalo@qca.qualcomm.com>
      37ca6335
    • K
      Add ath6kl cleaned up driver · bdcd8170
      Kalle Valo 提交于
      Last May we started working on cleaning up ath6kl driver which is
      currently in staging. The work has happened in a separate
      ath6kl-cleanup tree:
      
      http://git.kernel.org/?p=linux/kernel/git/kvalo/ath6kl-cleanup.git;a=summary
      
      After over 1100 (!) patches we have now reached a state where I would
      like to start discussing about pushing the driver to the wireless
      trees and replacing the staging driver.
      
      The driver is now a lot smaller and looks like a proper Linux driver.
      The size of the driver (measured with simple wc -l) dropped from 49
      kLOC to 18 kLOC and the number of the .c and .h files dropped from 107
      to 22. Most importantly the number of subdirectories reduced from 26
      to zero :)
      
      There are two remaining checkpatch warnings in the driver which we
      decided to omit for now:
      
      drivers/net/wireless/ath/ath6kl/debug.c:31:
        WARNING: printk() should include KERN_ facility level
      drivers/net/wireless/ath/ath6kl/sdio.c:527:
        WARNING: msleep < 20ms can sleep for up to 20ms;
        see Documentation/timers/timers-howto.txt
      
      The driver has endian annotations for all the hardware specific
      structures and there are no sparse errors. Unfortunately I don't have
      any big endian hardware to test that right now.
      
      We have been testing the driver both on x86 and arm platforms. The
      code is also compiled with sparc and parisc cross compilers.
      
      Notable missing features compared to the current staging driver are:
      
      o HCI over SDIO support
      o nl80211 testmode
      o firmware logging
      o suspend support
      
      Testmode, firmware logging and suspend support will be added soon. HCI
      over SDIO support will be more difficult as the HCI driver needs to
      share code with the wifi driver. This is something we need to research
      more.
      
      Also I want to point out the changes I did for signed endian support.
      As I wasn't able to find any support for signed endian annotations I
      decided to follow what NTFS has done and added my own. Grep for sle16
      and sle32, especially from wmi.h.
      
      Various people have been working on the cleanup, the hall of
      fame based on number of patches is:
      
         543  Vasanthakumar Thiagarajan
         403  Raja Mani
         252  Kalle Valo
          16  Vivek Natarajan
          12  Suraj Sumangala
           3  Joe Perches
           2  Jouni Malinen
      Signed-off-by: NVasanthakumar Thiagarajan <vthiagar@qca.qualcomm.com>
      Signed-off-by: NRaja Mani <rmani@qca.qualcomm.com>
      Signed-off-by: NVivek Natarajan <nataraja@qca.qualcomm.com>
      Signed-off-by: NSuraj Sumangala <surajs@qca.qualcomm.com>
      Signed-off-by: NJoe Perches <joe@perches.com>
      Signed-off-by: NJouni Malinen <jouni@qca.qualcomm.com>
      Signed-off-by: NKalle Valo <kvalo@qca.qualcomm.com>
      bdcd8170