hc
2024-05-09 b9d5c334faa47a75f1f28e72d203fc0334e8471d
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#include <linux/delay.h>
#include <linux/err.h>
#include <linux/export.h>
#include <linux/gpio.h>
#include <linux/interrupt.h>
#include <linux/irq.h>
#include <linux/kthread.h>
#include <linux/module.h>
#include <linux/spinlock.h>
//#include <linux/wakelock.h>
#include <wcn_bus.h>
#include "sdio_int.h"
#include "slp_mgr.h"
#include "slp_sdio.h"
#include "wcn_glb.h"
 
int slp_allow_sleep(void)
{
   union CP_SLP_CTL_REG reg_slp_ctl = {0};
 
   reg_slp_ctl.bit.cp_slp_ctl = 1;
   sprdwcn_bus_aon_writeb(REG_CP_SLP_CTL, reg_slp_ctl.reg);
 
   sdio_ap_int_cp0(ALLOW_CP_SLP);
   /* make SLP_CTL high_level keep 2 cycle of 32khz */
   udelay(65);
   return 0;
}
 
static void req_slp_isr(void)
{
   struct slp_mgr_t *slp_mgr;
 
   slp_mgr = slp_get_info();
   mutex_lock(&(slp_mgr->drv_slp_lock));
   /* allow sleep */
   if (slp_mgr->active_module == 0) {
       SLP_MGR_INFO("allow sleep\n");
       slp_allow_sleep();
 
       atomic_set(&(slp_mgr->cp2_state), STAY_SLPING);
   } else {
       SLP_MGR_INFO("forbid slp module-0x%x\n",
           slp_mgr->active_module);
   }
   mutex_unlock(&(slp_mgr->drv_slp_lock));
}
 
static void wakeup_ack_isr(void)
{
   struct slp_mgr_t *slp_mgr;
 
   slp_mgr = slp_get_info();
   if (STAY_SLPING == (atomic_read(&(slp_mgr->cp2_state)))) {
       SLP_MGR_INFO("wakeup ack");
       complete(&(slp_mgr->wakeup_ack_completion));
   } else
       SLP_MGR_INFO("discard wakeup ack");
}
 
int slp_pub_int_RegCb(void)
{
   sdio_pub_int_RegCb(WAKEUP_ACK, (PUB_INT_ISR)wakeup_ack_isr);
   sdio_pub_int_RegCb(REQ_SLP, (PUB_INT_ISR)req_slp_isr);
 
   return 0;
}