mirror of https://gitee.com/openkylin/linux.git
ath6kl: Add provision to define suspend policy in disconnected state.
It gives flexibility to the user to define suspend policy when the suspend mode is set to WOW and the device is in disconnected state at the time of suspend. New module parameter wow_mode is added to get the choice from the user. This parameter is valid only if the module parameter suspend_mode is set to WOW. To force WOW in connected state and cut power in disconnected state: suspend_mode=0x3 wow_mode=0x1 To force WOW in connected state and deep sleep in disconnected state (this is also the default wow_mode): suspend_mode=0x3 wow_mode=0x2 If there is no value specified to wow_mode during insmod, deep sleep mode will be tried in the disconnected state. kvalo: clarified commit log Signed-off-by: Raja Mani <rmani@qca.qualcomm.com> Signed-off-by: Kalle Valo <kvalo@qca.qualcomm.com>
This commit is contained in:
parent
068a4633bf
commit
1e9a905d9a
|
@ -2046,10 +2046,9 @@ int ath6kl_cfg80211_suspend(struct ath6kl *ar,
|
||||||
ath6kl_tx_data_cleanup(ar);
|
ath6kl_tx_data_cleanup(ar);
|
||||||
|
|
||||||
ret = ath6kl_wow_suspend(ar, wow);
|
ret = ath6kl_wow_suspend(ar, wow);
|
||||||
if (ret) {
|
if (ret)
|
||||||
ath6kl_err("wow suspend failed: %d\n", ret);
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
|
||||||
ar->state = ATH6KL_STATE_WOW;
|
ar->state = ATH6KL_STATE_WOW;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
|
@ -27,12 +27,14 @@
|
||||||
|
|
||||||
unsigned int debug_mask;
|
unsigned int debug_mask;
|
||||||
static unsigned int suspend_mode;
|
static unsigned int suspend_mode;
|
||||||
|
static unsigned int wow_mode;
|
||||||
static unsigned int uart_debug;
|
static unsigned int uart_debug;
|
||||||
static unsigned int ath6kl_p2p;
|
static unsigned int ath6kl_p2p;
|
||||||
static unsigned int testmode;
|
static unsigned int testmode;
|
||||||
|
|
||||||
module_param(debug_mask, uint, 0644);
|
module_param(debug_mask, uint, 0644);
|
||||||
module_param(suspend_mode, uint, 0644);
|
module_param(suspend_mode, uint, 0644);
|
||||||
|
module_param(wow_mode, uint, 0644);
|
||||||
module_param(uart_debug, uint, 0644);
|
module_param(uart_debug, uint, 0644);
|
||||||
module_param(ath6kl_p2p, uint, 0644);
|
module_param(ath6kl_p2p, uint, 0644);
|
||||||
module_param(testmode, uint, 0644);
|
module_param(testmode, uint, 0644);
|
||||||
|
@ -119,6 +121,13 @@ int ath6kl_core_init(struct ath6kl *ar)
|
||||||
else
|
else
|
||||||
ar->suspend_mode = 0;
|
ar->suspend_mode = 0;
|
||||||
|
|
||||||
|
if (suspend_mode == WLAN_POWER_STATE_WOW &&
|
||||||
|
(wow_mode == WLAN_POWER_STATE_CUT_PWR ||
|
||||||
|
wow_mode == WLAN_POWER_STATE_DEEP_SLEEP))
|
||||||
|
ar->wow_suspend_mode = wow_mode;
|
||||||
|
else
|
||||||
|
ar->wow_suspend_mode = 0;
|
||||||
|
|
||||||
if (uart_debug)
|
if (uart_debug)
|
||||||
ar->conf_flags |= ATH6KL_CONF_UART_DEBUG;
|
ar->conf_flags |= ATH6KL_CONF_UART_DEBUG;
|
||||||
|
|
||||||
|
|
|
@ -636,6 +636,7 @@ struct ath6kl {
|
||||||
|
|
||||||
u16 conf_flags;
|
u16 conf_flags;
|
||||||
u16 suspend_mode;
|
u16 suspend_mode;
|
||||||
|
u16 wow_suspend_mode;
|
||||||
wait_queue_head_t event_wq;
|
wait_queue_head_t event_wq;
|
||||||
struct ath6kl_mbox_info mbox_info;
|
struct ath6kl_mbox_info mbox_info;
|
||||||
|
|
||||||
|
|
|
@ -836,6 +836,7 @@ static int ath6kl_sdio_suspend(struct ath6kl *ar, struct cfg80211_wowlan *wow)
|
||||||
struct ath6kl_sdio *ar_sdio = ath6kl_sdio_priv(ar);
|
struct ath6kl_sdio *ar_sdio = ath6kl_sdio_priv(ar);
|
||||||
struct sdio_func *func = ar_sdio->func;
|
struct sdio_func *func = ar_sdio->func;
|
||||||
mmc_pm_flag_t flags;
|
mmc_pm_flag_t flags;
|
||||||
|
bool try_deepsleep = false;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (ar->state == ATH6KL_STATE_SCHED_SCAN) {
|
if (ar->state == ATH6KL_STATE_SCHED_SCAN) {
|
||||||
|
@ -862,14 +863,21 @@ static int ath6kl_sdio_suspend(struct ath6kl *ar, struct cfg80211_wowlan *wow)
|
||||||
goto cut_pwr;
|
goto cut_pwr;
|
||||||
|
|
||||||
ret = ath6kl_cfg80211_suspend(ar, ATH6KL_CFG_SUSPEND_WOW, wow);
|
ret = ath6kl_cfg80211_suspend(ar, ATH6KL_CFG_SUSPEND_WOW, wow);
|
||||||
if (ret)
|
if (ret && ret != -ENOTCONN)
|
||||||
goto cut_pwr;
|
ath6kl_err("wow suspend failed: %d\n", ret);
|
||||||
|
|
||||||
return 0;
|
if (ret && (!ar->wow_suspend_mode ||
|
||||||
|
ar->wow_suspend_mode == WLAN_POWER_STATE_DEEP_SLEEP))
|
||||||
|
try_deepsleep = true;
|
||||||
|
else if (ret &&
|
||||||
|
ar->wow_suspend_mode == WLAN_POWER_STATE_CUT_PWR)
|
||||||
|
goto cut_pwr;
|
||||||
|
if (!ret)
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ar->suspend_mode == WLAN_POWER_STATE_DEEP_SLEEP ||
|
if (ar->suspend_mode == WLAN_POWER_STATE_DEEP_SLEEP ||
|
||||||
!ar->suspend_mode) {
|
!ar->suspend_mode || try_deepsleep) {
|
||||||
|
|
||||||
flags = sdio_get_host_pm_caps(func);
|
flags = sdio_get_host_pm_caps(func);
|
||||||
if (!(flags & MMC_PM_KEEP_POWER))
|
if (!(flags & MMC_PM_KEEP_POWER))
|
||||||
|
|
Loading…
Reference in New Issue