1. 12 10月, 2019 1 次提交
    • J
      cfg80211: add and use strongly typed element iteration macros · ad180cac
      Johannes Berg 提交于
      commit 0f3b07f027f87a38ebe5c436490095df762819be upstream.
      
      Rather than always iterating elements from frames with pure
      u8 pointers, add a type "struct element" that encapsulates
      the id/datalen/data format of them.
      
      Then, add the element iteration macros
       * for_each_element
       * for_each_element_id
       * for_each_element_extid
      
      which take, as their first 'argument', such a structure and
      iterate through a given u8 array interpreting it as elements.
      
      While at it and since we'll need it, also add
       * for_each_subelement
       * for_each_subelement_id
       * for_each_subelement_extid
      
      which instead of taking data/length just take an outer element
      and use its data/datalen.
      
      Also add for_each_element_completed() to determine if any of
      the loops above completed, i.e. it was able to parse all of
      the elements successfully and no data remained.
      
      Use for_each_element_id() in cfg80211_find_ie_match() as the
      first user of this.
      Signed-off-by: NJohannes Berg <johannes.berg@intel.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      ad180cac
  2. 19 6月, 2018 1 次提交
  3. 15 6月, 2018 1 次提交
  4. 23 2月, 2018 1 次提交
  5. 19 2月, 2018 1 次提交
  6. 02 10月, 2017 1 次提交
  7. 30 6月, 2017 1 次提交
  8. 13 6月, 2017 2 次提交
  9. 28 4月, 2017 1 次提交
  10. 27 4月, 2017 3 次提交
  11. 31 3月, 2017 1 次提交
  12. 06 3月, 2017 3 次提交
  13. 08 2月, 2017 1 次提交
  14. 27 1月, 2017 1 次提交
  15. 05 1月, 2017 1 次提交
  16. 27 10月, 2016 3 次提交
  17. 30 6月, 2016 2 次提交
  18. 06 4月, 2016 2 次提交
    • F
      mac80211: add A-MSDU tx support · 6e0456b5
      Felix Fietkau 提交于
      Requires software tx queueing and fast-xmit support. For good
      performance, drivers need frag_list support as well. This avoids the
      need for copying data of aggregated frames. Running without it is only
      supported for debugging purposes.
      
      To avoid performance and packet size issues, the rate control module or
      driver needs to limit the maximum A-MSDU size by setting
      max_rc_amsdu_len in struct ieee80211_sta.
      Signed-off-by: NFelix Fietkau <nbd@openwrt.org>
      [fix locking issue]
      Signed-off-by: NJohannes Berg <johannes.berg@intel.com>
      6e0456b5
    • J
      mac80211: add fast-rx path · 49ddf8e6
      Johannes Berg 提交于
      The regular RX path has a lot of code, but with a few
      assumptions on the hardware it's possible to reduce the
      amount of code significantly. Currently the assumptions
      on the driver are the following:
       * hardware/driver reordering buffer (if supporting aggregation)
       * hardware/driver decryption & PN checking (if using encryption)
       * hardware/driver did de-duplication
       * hardware/driver did A-MSDU deaggregation
       * AP_LINK_PS is used (in AP mode)
       * no client powersave handling in mac80211 (in client mode)
      
      of which some are actually checked per packet:
       * de-duplication
       * PN checking
       * decryption
      and additionally packets must
       * not be A-MSDU (have been deaggregated by driver/device)
       * be data packets
       * not be fragmented
       * be unicast
       * have RFC 1042 header
      
      Additionally dynamically we assume:
       * no encryption or CCMP/GCMP, TKIP/WEP/other not allowed
       * station must be authorized
       * 4-addr format not enabled
      
      Some data needed for the RX path is cached in a new per-station
      "fast_rx" structure, so that we only need to look at this and
      the packet, no other memory when processing packets on the fast
      RX path.
      
      After doing the above per-packet checks, the data path collapses
      down to a pretty simple conversion function taking advantage of
      the data cached in the small fast_rx struct.
      
      This should speed up the RX processing, and will make it easier
      to reason about parallelizing RX (for which statistics will need
      to be per-CPU still.)
      Signed-off-by: NJohannes Berg <johannes.berg@intel.com>
      49ddf8e6
  19. 05 4月, 2016 1 次提交
  20. 24 2月, 2016 1 次提交
  21. 14 1月, 2016 1 次提交
  22. 13 10月, 2015 2 次提交
  23. 09 10月, 2015 1 次提交
  24. 22 9月, 2015 2 次提交
  25. 14 8月, 2015 1 次提交
  26. 27 1月, 2015 2 次提交
  27. 20 11月, 2014 2 次提交