Commit 7321095c authored by Wen Gong's avatar Wen Gong Committed by Kalle Valo

ath10k: enable wow feature for sdio chip

sdio does not support wow, this patch is to enable it. When system enter
sleep state, if wowlan is enabled, then sdio chip will keep power if
platform support keep power, after resume, it will not need to re-load
firmware again.

Tested with QCA6174 SDIO with firmware
WLAN.RMH.4.4.1-00029.
Signed-off-by: default avatarWen Gong <wgong@codeaurora.org>
Signed-off-by: default avatarKalle Valo <kvalo@codeaurora.org>
parent 5d246729
...@@ -1859,7 +1859,7 @@ static void ath10k_sdio_hif_stop(struct ath10k *ar) ...@@ -1859,7 +1859,7 @@ static void ath10k_sdio_hif_stop(struct ath10k *ar)
static int ath10k_sdio_hif_suspend(struct ath10k *ar) static int ath10k_sdio_hif_suspend(struct ath10k *ar)
{ {
return -EOPNOTSUPP; return 0;
} }
static int ath10k_sdio_hif_resume(struct ath10k *ar) static int ath10k_sdio_hif_resume(struct ath10k *ar)
...@@ -2009,7 +2009,26 @@ static const struct ath10k_hif_ops ath10k_sdio_hif_ops = { ...@@ -2009,7 +2009,26 @@ static const struct ath10k_hif_ops ath10k_sdio_hif_ops = {
*/ */
static int ath10k_sdio_pm_suspend(struct device *device) static int ath10k_sdio_pm_suspend(struct device *device)
{ {
return 0; struct sdio_func *func = dev_to_sdio_func(device);
struct ath10k_sdio *ar_sdio = sdio_get_drvdata(func);
struct ath10k *ar = ar_sdio->ar;
mmc_pm_flag_t pm_flag, pm_caps;
int ret;
if (!device_may_wakeup(ar->dev))
return 0;
pm_flag = MMC_PM_KEEP_POWER;
ret = sdio_set_host_pm_flags(func, pm_flag);
if (ret) {
pm_caps = sdio_get_host_pm_caps(func);
ath10k_warn(ar, "failed to set sdio host pm flags (0x%x, 0x%x): %d\n",
pm_flag, pm_caps, ret);
return ret;
}
return ret;
} }
static int ath10k_sdio_pm_resume(struct device *device) static int ath10k_sdio_pm_resume(struct device *device)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment