1. 08 5月, 2010 15 次提交
    • L
      ath9k_common: drop incomming frames with an invalid hardware rate · 6f256de7
      Luis R. Rodriguez 提交于
      ath9k_common (used by ath9k and ath9k_htc) trusts the frames
      blessed by hardware as OK are infact correct even if the rate
      seen by the driver is unrecognized. ath9k_common just treats
      these frames in mac80211 as frames as frames under 1 mbps rate.
      It seems this might not be the best thing to do as other parts of
      the frame might not be valid so just drop these frames for now.
      Signed-off-by: NLuis R. Rodriguez <lrodriguez@atheros.com>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      6f256de7
    • L
      ath9k_common: move the rate status setting into ath9k_process_rate() · 8e155994
      Luis R. Rodriguez 提交于
      This has no real functional change, this just moves the setting the
      the mac80211 rate index into ath9k_process_rate(). This allows us
      to eventually make ath9k_process_rate() return a negative value
      in case we have detected a specific case rate situation which should
      have been ignored.
      Signed-off-by: NLuis R. Rodriguez <lrodriguez@atheros.com>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      8e155994
    • J
      rtl8180: add software-based support for IBSS mode · c809e86c
      John W. Linville 提交于
      Device documentation suggests that hardware support for beaconing
      is available.  But I implemented software-based beacon generation
      as an experiment and it seems better to have that working now rather
      than waiting for something better to materialize.
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      c809e86c
    • J
      rtl8180: assign sequence numbers in the driver · 51e080de
      John W. Linville 提交于
      This is a step towards support for beaconing modes of operation.
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      51e080de
    • J
      mac80211: set IEEE80211_TX_CTL_FIRST_FRAGMENT for beacons · a472e71b
      John W. Linville 提交于
      Also simplify the flags assignment into a single statement at the
      end of ieee80211_beacon_get_tim.
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      a472e71b
    • I
      rt2x00: Fix RF3052 channel initialization · 55f9321a
      Ivo van Doorn 提交于
      Update channel initialization for the RF3052 chipset.
      According to the Ralink drivers, the rt3x array must be
      used for this chipset, rather then the rt2x array.
      
      Furthermore RF3052 supports the 5GHz band, extend
      the rt3x array with the 5GHz channels, and use them
      for the RF3052 chip.
      Signed-off-by: NIvo van Doorn <IvDoorn@gmail.com>
      Acked-by: NGertjan van Wingerde <gwingerde@gmail.com>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      55f9321a
    • H
      rt2x00: rt2800: don't overwrite SIFS values on erp changes · 809bfe81
      Helmut Schaa 提交于
      The SIFS value is a constant and doesn't need to be updated on erp changes.
      Furthermore the code used 10us for both, the OFDM SIFS and CCK SIFS time
      which broke CTS protected 11g connections (see patch "rt2x00: rt2800: update
      initial SIFS values" for details).
      Signed-off-by: NHelmut Schaa <helmut.schaa@googlemail.com>
      Acked-by: NIvo van Doorn <IvDoorn@gmail.com>
      Acked-by: NGertjan van Wingerde <gwingerde@gmail.com>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      809bfe81
    • H
      rt2x00: rt2800: update initial SIFS values · a21c2ab4
      Helmut Schaa 提交于
      Currently the CCK and OFDM SIFS value is set to 32us. This value is neither
      used by the Ralink driver nor specified in 802.11.
      
      Instead of using 10us for CCK SIFS (as defined in 802.11) use 16us like in the
      Ralink drivers. And indeed using a SIFS value of 10us breaks connectivity with
      11g + CTS protected connections. Add a comment to the code why we don't use 10us
      for CCK SIFS value.
      
      The OFDM SIFS value is set to 16us (as defined in 802.11 and also used by the
      Ralink drivers).
      Signed-off-by: NHelmut Schaa <helmut.schaa@googlemail.com>
      Acked-by: NIvo van Doorn <IvDoorn@gmail.com>
      Acked-by: NGertjan van Wingerde <gwingerde@gmail.com>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      a21c2ab4
    • S
      ath9k_htc: Fix beaconing in IBSS mode · 9c6dda4e
      Sujith 提交于
      The current way of managing beaconing in ad-hoc
      mode has a subtle race - the beacon obtained from mac80211
      is freed in the SWBA handler rather than the TX
      completion routine. But transmission of beacons goes
      through the normal SKB queue maintained in hif_usb,
      leading to a situation where __skb_dequeue() in the TX
      completion handler goes kaput.
      
      Fix this by simply getting a beacon from mac80211 for
      every SWBA and free it in its completion routine.
      Signed-off-by: NSujith <Sujith.Manoharan@atheros.com>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      9c6dda4e
    • J
      mac80211: improve HT channel handling · 0aaffa9b
      Johannes Berg 提交于
      Currently, when one interface switches HT mode,
      all others will follow along. This is clearly
      undesirable, since the new one might switch to
      no-HT while another one is operating in HT.
      
      Address this issue by keeping track of the HT
      mode per interface, and allowing only changes
      that are compatible, i.e. switching into HT40+
      is not possible when another interface is in
      HT40-, in that case the second one needs to
      fall back to HT20.
      
      Also, to allow drivers to know what's going on,
      store the per-interface HT mode (channel type)
      in the virtual interface's bss_conf.
      Signed-off-by: NJohannes Berg <johannes@sipsolutions.net>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      0aaffa9b
    • J
      cfg80211/mac80211: better channel handling · f444de05
      Johannes Berg 提交于
      Currently (all tested with hwsim) you can do stupid
      things like setting up an AP on a certain channel,
      then adding another virtual interface and making
      that associate on another channel -- this will make
      the beaconing to move channel but obviously without
      the necessary IEs data update.
      
      In order to improve this situation, first make the
      configuration APIs (cfg80211 and nl80211) aware of
      multi-channel operation -- we'll eventually need
      that in the future anyway. There's one userland API
      change and one API addition. The API change is that
      now SET_WIPHY must be called with virtual interface
      index rather than only wiphy index in order to take
      effect for that interface -- luckily all current
      users (hostapd) do that. For monitor interfaces, the
      old setting is preserved, but monitors are always
      slaved to other devices anyway so no guarantees.
      
      The second userland API change is the introduction
      of a per virtual interface SET_CHANNEL command, that
      hostapd should use going forward to make it easier
      to understand what's going on (it can automatically
      detect a kernel with this command).
      
      Other than mac80211, no existing cfg80211 drivers
      are affected by this change because they only allow
      a single virtual interface.
      
      mac80211, however, now needs to be aware that the
      channel settings are per interface now, and needs
      to disallow (for now) real multi-channel operation,
      which is another important part of this patch.
      
      One of the immediate benefits is that you can now
      start hostapd to operate on a hardware that already
      has a connection on another virtual interface, as
      long as you specify the same channel.
      
      Note that two things are left unhandled (this is an
      improvement -- not a complete fix):
      
       * different HT/no-HT modes
      
         currently you could start an HT AP and then
         connect to a non-HT network on the same channel
         which would configure the hardware for no HT;
         that can be fixed fairly easily
      
       * CSA
      
         An AP we're connected to on a virtual interface
         might indicate switching channels, and in that
         case we would follow it, regardless of how many
         other interfaces are operating; this requires
         more effort to fix but is pretty rare after all
      Signed-off-by: NJohannes Berg <johannes@sipsolutions.net>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      f444de05
    • J
      mac80211: fix BSS info reconfiguration · ac8dd506
      Johannes Berg 提交于
      When reconfiguring an interface due to a previous
      hardware restart, mac80211 will currently include
      the new IBSS flag on non-IBSS interfaces which may
      confuse drivers.
      
      Instead of doing the ~0 trick, simply spell out
      which things are going to be reconfigured.
      Signed-off-by: NJohannes Berg <johannes@sipsolutions.net>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      ac8dd506
    • D
      orinoco: refactor xmit path · bac6fafd
      David Kilroy 提交于
      ... so orinoco_usb can share some common functionality.
      
      Handle 802.2 encapsulation and MIC calculation in that function.
      The 802.3 header is prepended to the SKB. The calculated MIC is written
      to a specified buffer. Also modify the transmit control word that will
      be passed onto the hardware to specify whether the MIC is present, and
      the key used.
      Signed-off-by: NDavid Kilroy <kilroyd@googlemail.com>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      bac6fafd
    • F
      ath9k: fix another source of corrupt frames · 3ef83d74
      Felix Fietkau 提交于
      Atheros hardware supports receiving frames that span multiple
      descriptors and buffers. In this case, the rx status of every
      descriptor except for the last one is invalid and may contain random
      data. Because the driver does not support this, it needs to drop such
      frames.
      Signed-off-by: NFelix Fietkau <nbd@openwrt.org>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      3ef83d74
    • C
      ar9170usb: remove deprecated aggregation code · f3926b49
      Christian Lamparter 提交于
      This patch removes the incomplete AMPDU implementation in ar9170usb.
      
      The code in question is:
       * too big and complex (more than 550 SLOC.)
         This is enough to qualify for a new separate code file!
      
       * unbalanced quantity & quality
      	over-engineered areas like:
      		* xmit scheduling and queuing frames for multiple HT peers
      		* redundant frame sorting
      	are confronted by gaping holes:
      		* accurate transmission feedback
      		* firmware error-handling and device reset
      		* HT rate control algorithm
      
       * error-prone
      	Since its inclusion, hardly anything was done to fix
      	any of the outlined flaws from the initial commit message.
      
         => This also indicates poor maintainability.
      
       * relies heavily on several spinlocks.
      
      As a result of this shortcomings, the code is slow and does not
      even support the most basic 11n requirement: HT station mode.
      
      Therefore, I request to purge my heap of **** from the kernel:
      "ar9170: implement transmit aggregation".
      
      The next item on the agenda is: (re-)start from scratch with
      an adequate design to accommodate the special requirements
      and features of the available frameworks and tools.
      Signed-off-by: NChristian Lamparter <chunkeey@googlemail.com>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      f3926b49
  2. 06 5月, 2010 2 次提交
  3. 05 5月, 2010 6 次提交
  4. 04 5月, 2010 17 次提交