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
This commit is contained in:

committed by
snandini

parent
3d5a0c6aba
commit
4aa291d159
@@ -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);
|
||||
|
@@ -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
|
||||
|
@@ -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));
|
||||
}
|
||||
|
||||
|
@@ -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;
|
||||
|
Reference in New Issue
Block a user