1. 01 3月, 2014 2 次提交
    • B
      mwifiex: remove global variable cmd_wait_q_required · fa0ecbb9
      Bing Zhao 提交于
      There is a race condition while queuing synchronous command and
      asynchronous command requested from different threads, because
      the wait_q_enabled flag is set based on a global variable
      cmd_wait_q_required.
      
      The issue is fixed by removing this global variable and using a
      unified function with an argument 'sync' passed into the
      function.
      Signed-off-by: NBing Zhao <bzhao@marvell.com>
      Signed-off-by: NAmitkumar Karwar <akarwar@marvell.com>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      fa0ecbb9
    • P
      mwifiex: Track BA sequence number reset · 8acbea61
      Paul Stewart 提交于
      Some stations reset the sequence number for traffic-ids (TIDs)
      as they initiate a block-ACK session.  In order to detect such
      behavior, mwifiex must note the starting sequence number given
      during the ADDBA request.  If the first received sequence number
      after the ADDBA falls outside the receive window for this TID but
      after the the ADDBA starting sequence number, we can assume that
      this AP has reset its sequence number during the ADDBA.  In this
      case we must adjust the input window backward to incorporate this
      received sequence number instead of ignoring it.  Otherwise, we
      could fail to successfully retrieve an arbitrarily large number
      of downstream frames at the beginning of the block-ACK session.
      Signed-off-by: NPaul Stewart <pstew@chromium.org>
      Acked-by: NBing Zhao <bzhao@marvell.com>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      8acbea61
  2. 13 2月, 2014 14 次提交
  3. 05 2月, 2014 1 次提交
  4. 09 1月, 2014 1 次提交
  5. 19 12月, 2013 2 次提交
  6. 10 12月, 2013 1 次提交
  7. 27 8月, 2013 2 次提交
  8. 02 8月, 2013 1 次提交
  9. 27 7月, 2013 1 次提交
  10. 24 7月, 2013 3 次提交
  11. 23 7月, 2013 1 次提交
    • D
      mwifiex: fix IRQ enable/disable · 232fde06
      Daniel Drake 提交于
      During tear down (e.g. mwifiex_sdio_remove during system suspend),
      mwifiex left IRQs enabled for a significant period of time when it was
      unable to handle them correctly. This caused interrupt storms and
      interfered with the bluetooth interface on the same SDIO card.
      
      Solve this by disabling interrupts at the point when they can no longer
      be handled correctly, which is at the start of mwifiex_remove_card().
      
      For cleanliness, we now enable interrupts in the mwifiex_add_card() path,
      to be symmetrical with the disabling of interrupts. We also couple the
      registration of the sdio IRQ handler with the actual enable/disable of
      interrupts at the hardware level.
      
      I also removed a write to this register in mwifiex_init_sdio which seemed
      pointless and won't cause any ill effects now that we only register
      the SDIO IRQ handler when we are ready to accept interrupts.
      
      Includes some corrections from Amitkumar Karwar.
      Signed-off-by: NDaniel Drake <dsd@laptop.org>
      Acked-by: NBing Zhao <bzhao@marvell.com>
      Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
      232fde06
  12. 20 6月, 2013 2 次提交
  13. 23 5月, 2013 3 次提交
  14. 24 4月, 2013 1 次提交
  15. 09 4月, 2013 3 次提交
  16. 02 4月, 2013 2 次提交