qcacmn: Do explicit system wakeup for group intr in D0-WoW

In P2P GO mode, on system suspend to s2idle state, bus
is suspended and D0-WoW is enabled. Ping requests from
P2P client cause the REO interrupt to fire but since
system is in s2idle state, system is not woken-up. This
results in destination unreachability or large rtt for
ping on P2P client.

Fix is to do explicit system wakeup when group interrupts
fire after system is in suspend state.

Change-Id: Ic6f51c3fc8bad6da29adf58972890677a81f2064
CRs-Fixed: 2765037
Esse commit está contido em:
Yeshwanth Sriram Guntuka
2020-09-04 16:23:46 +05:30
commit de snandini
commit 4aa291d159
4 arquivos alterados com 36 adições e 1 exclusões

Ver arquivo

@@ -861,6 +861,23 @@ static inline void hif_check_and_trigger_ut_resume(struct hif_softc *scn)
}
#endif
/**
* hif_check_and_trigger_sys_resume() - Check for bus suspend and
* trigger system resume
* @scn: hif context
* @irq: irq number
*
* Return: None
*/
static inline void
hif_check_and_trigger_sys_resume(struct hif_softc *scn, int irq)
{
if (scn->bus_suspended && scn->linkstate_vote) {
hif_info_rl("interrupt rcvd:%d trigger sys resume", irq);
qdf_pm_system_wakeup();
}
}
/**
* hif_ext_group_interrupt_handler() - handler for related interrupts
* @irq: irq number of the interrupt
@@ -895,6 +912,9 @@ irqreturn_t hif_ext_group_interrupt_handler(int irq, void *context)
* in reality APSS didn't really suspend.
*/
hif_check_and_trigger_ut_resume(scn);
hif_check_and_trigger_sys_resume(scn, irq);
qdf_atomic_inc(&scn->active_grp_tasklet_cnt);
hif_ext_group->sched_ops->schedule(hif_ext_group);

Ver arquivo

@@ -257,6 +257,8 @@ struct hif_softc {
#endif
uint32_t irq_unlazy_disable;
/* Should the unlzay support for interrupt delivery be disabled */
/* Flag to indicate whether bus is suspended */
bool bus_suspended;
};
static inline

Ver arquivo

@@ -311,11 +311,20 @@ void hif_ipci_prevent_linkdown(struct hif_softc *scn, bool flag)
int hif_ipci_bus_suspend(struct hif_softc *scn)
{
return hif_apps_enable_irq_wake(GET_HIF_OPAQUE_HDL(scn));
int ret;
ret = hif_apps_enable_irq_wake(GET_HIF_OPAQUE_HDL(scn));
if (!ret)
scn->bus_suspended = true;
return ret;
}
int hif_ipci_bus_resume(struct hif_softc *scn)
{
scn->bus_suspended = false;
return hif_apps_disable_irq_wake(GET_HIF_OPAQUE_HDL(scn));
}

Ver arquivo

@@ -2320,6 +2320,8 @@ int hif_pci_bus_suspend(struct hif_softc *scn)
/* Stop the HIF Sleep Timer */
hif_cancel_deferred_target_sleep(scn);
scn->bus_suspended = true;
return 0;
}
@@ -2371,6 +2373,8 @@ int hif_pci_bus_resume(struct hif_softc *scn)
{
int errno;
scn->bus_suspended = false;
errno = __hif_check_link_status(scn);
if (errno)
return errno;