2 ** Id: //Department/DaVinci/BRANCHES/MT6620_WIFI_DRIVER_V2_3/include/pwr_mgt.h#1
6 \brief In this file we define the STATE and EVENT for Power Management FSM.
8 The SCAN FSM is responsible for performing SCAN behavior when the Arbiter enter
9 ARB_STATE_SCAN. The STATE and EVENT for SCAN FSM are defined here with detail
16 /*******************************************************************************
17 * C O M P I L E R F L A G S
18 ********************************************************************************
21 /*******************************************************************************
22 * E X T E R N A L R E F E R E N C E S
23 ********************************************************************************
26 /*******************************************************************************
28 ********************************************************************************
30 #define PM_UAPSD_AC0 (BIT(0))
31 #define PM_UAPSD_AC1 (BIT(1))
32 #define PM_UAPSD_AC2 (BIT(2))
33 #define PM_UAPSD_AC3 (BIT(3))
35 #define PM_UAPSD_ALL (PM_UAPSD_AC0 | PM_UAPSD_AC1 | PM_UAPSD_AC2 | PM_UAPSD_AC3)
36 #define PM_UAPSD_NONE 0
39 /*******************************************************************************
41 ********************************************************************************
43 typedef struct _PM_PROFILE_SETUP_INFO_T
{
45 UINT_8 ucBmpDeliveryAC
; /* 0: AC_BE, 1: AC_BK, 2: AC_VI, 3: AC_VO */
46 UINT_8 ucBmpTriggerAC
; /* 0: AC_BE, 1: AC_BK, 2: AC_VI, 3: AC_VO */
48 UINT_8 ucUapsdSp
; /* Number of triggered packets in UAPSD */
50 } PM_PROFILE_SETUP_INFO_T
, *P_PM_PROFILE_SETUP_INFO_T
;
53 /*******************************************************************************
55 ********************************************************************************
58 /*******************************************************************************
59 * P R I V A T E D A T A
60 ********************************************************************************
63 /*******************************************************************************
65 ********************************************************************************
68 #if !CFG_ENABLE_FULL_PM
69 #define ACQUIRE_POWER_CONTROL_FROM_PM(_prAdapter)
70 #define RECLAIM_POWER_CONTROL_TO_PM(_prAdapter, _fgEnableGINT_in_IST)
72 #define ACQUIRE_POWER_CONTROL_FROM_PM(_prAdapter) \
74 if (_prAdapter->fgIsFwOwn) { \
75 nicpmSetDriverOwn(_prAdapter); \
77 /* Increase Block to Enter Low Power Semaphore count */ \
78 GLUE_INC_REF_CNT(_prAdapter->u4PwrCtrlBlockCnt); \
81 #define RECLAIM_POWER_CONTROL_TO_PM(_prAdapter, _fgEnableGINT_in_IST) \
83 ASSERT(_prAdapter->u4PwrCtrlBlockCnt != 0); \
84 /* Decrease Block to Enter Low Power Semaphore count */ \
85 GLUE_DEC_REF_CNT(_prAdapter->u4PwrCtrlBlockCnt); \
86 if (_prAdapter->fgWiFiInSleepyState && (_prAdapter->u4PwrCtrlBlockCnt == 0)) { \
87 nicpmSetFWOwn(_prAdapter, _fgEnableGINT_in_IST); \
93 /*******************************************************************************
94 * F U N C T I O N D E C L A R A T I O N S
95 ********************************************************************************
98 /*******************************************************************************
100 ********************************************************************************
103 #endif /* _PWR_MGT_H */