1. 22 6月, 2012 5 次提交
    • I
      wlcore: Propagate errors from wlcore_raw_*_data functions · 8b7c0fc3
      Ido Yariv 提交于
      wlcore_raw_read_data is called when the FW status is read which happens
      while handling interrupts and when the FW log is read following a
      recovery. Request a recovery in the former case, and don't read the FW
      log in case the FW status read failed.
      Signed-off-by: NIdo Yariv <ido@wizery.com>
      Signed-off-by: NLuciano Coelho <coelho@ti.com>
      8b7c0fc3
    • I
      wlcore: Change raw io functions to return errors · 0c2a6ce0
      Ido Yariv 提交于
      Make wl1271_raw_write and wl1271_raw_read return errors so the driver
      could handle these appropriately.
      Since the prototype has changed, also rename the prefix of these
      functions to wlcore.
      Signed-off-by: NIdo Yariv <ido@wizery.com>
      Signed-off-by: NLuciano Coelho <coelho@ti.com>
      0c2a6ce0
    • I
      wlcore: Change read/write ops to return errors · 02eb1d9d
      Ido Yariv 提交于
      While bus operations may fail, either due to HW or FW issues, these are
      never propagated to higher layers. As a result, the core driver has no
      way of knowing that the operations failed, and will only recover if high
      level logic requires it (e.g. no command completion).
      
      Change read/write bus operations to return errors to let higher layer
      functionality handle these.
      Signed-off-by: NIdo Yariv <ido@wizery.com>
      Signed-off-by: NLuciano Coelho <coelho@ti.com>
      02eb1d9d
    • I
      wlcore: Disable interrupts while recovering · b666bb7f
      Ido Yariv 提交于
      In case a recovery is initiated, the FW can no longer be trusted, and
      the driver should not handle any new FW events.
      
      Disable the interrupt handler when a recovery is scheduled and balance
      it back in the op_stop callback.
      Signed-off-by: NIdo Yariv <ido@wizery.com>
      Signed-off-by: NLuciano Coelho <coelho@ti.com>
      b666bb7f
    • I
      wlcore: Fix sdio out-of-sync power state · 645865fc
      Ido Yariv 提交于
      wl12xx_sdio_power_off() manually powers down the card regardless of the
      runtime pm state. If wl12xx_sdio_power_on() is called before the card
      was suspended by runtime PM, it will not power up the card.
      
      As part of the HW detection, the chip's power is toggled. Since this
      happens in the context of probing sdio, the power reference counter will
      be higher than zero. As a result, when wl12xx_sdio_power_off() is
      called, the chip will be powered down while still having a positive
      power reference counter. If the interface is quickly activated, the
      driver might try to transfer data to a powered off chip.
      
      Fix this by ensuring that wl12xx_sdio_power_on() explicitly powers on
      the chip in case runtime pm claims the chip is already powered on. To
      avoid cases in which it is not possible to determine if the chip was
      really powered on (card's power reference counter is positive), operate
      on the mmc_card instead of the function.
      
      Also verify that the chip is indeed powered on before powering off, to
      avoid wrong reference counter values in error cases.
      Signed-off-by: NIdo Yariv <ido@wizery.com>
      Signed-off-by: NLuciano Coelho <coelho@ti.com>
      645865fc
  2. 21 6月, 2012 12 次提交
  3. 14 6月, 2012 6 次提交
  4. 08 6月, 2012 14 次提交
  5. 07 6月, 2012 3 次提交