2017-06-21 00:00:20 +00:00
|
|
|
#ifndef __FREERTOS_PMU_H_
|
|
|
|
#define __FREERTOS_PMU_H_
|
|
|
|
|
|
|
|
#ifdef CONFIG_PLATFORM_8195A
|
|
|
|
#include "sleep_ex_api.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef BIT
|
|
|
|
#define BIT(n) (1<<n)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_PLATFORM_8195A
|
|
|
|
#define DEFAULT_WAKEUP_EVENT (SLEEP_WAKEUP_BY_STIMER | SLEEP_WAKEUP_BY_GTIMER | SLEEP_WAKEUP_BY_GPIO_INT | SLEEP_WAKEUP_BY_WLAN)
|
|
|
|
|
|
|
|
typedef enum PMU_DEVICE {
|
|
|
|
|
|
|
|
PMU_OS = 0,
|
|
|
|
PMU_WLAN_DEVICE = 1,
|
|
|
|
PMU_LOGUART_DEVICE = 2,
|
|
|
|
PMU_SDIO_DEVICE = 3,
|
|
|
|
|
|
|
|
PMU_DEV_USER_BASE= 16,
|
|
|
|
|
|
|
|
PMU_MAX = 31
|
|
|
|
|
|
|
|
} PMU_DEVICE;
|
|
|
|
|
|
|
|
#ifndef BIT
|
|
|
|
#define BIT(n) (1<<n)
|
|
|
|
#endif
|
|
|
|
// wakelock for system usage
|
|
|
|
#define WAKELOCK_OS BIT(PMU_OS)
|
|
|
|
#define WAKELOCK_WLAN BIT(PMU_WLAN_DEVICE)
|
|
|
|
#define WAKELOCK_LOGUART BIT(PMU_LOGUART_DEVICE)
|
|
|
|
#define WAKELOCK_SDIO_DEVICE BIT(PMU_SDIO_DEVICE)
|
|
|
|
|
|
|
|
// wakelock for user defined
|
|
|
|
#define WAKELOCK_USER_BASE BIT(PMU_DEV_USER_BASE)
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_PLATFORM_8711B
|
|
|
|
typedef enum {
|
2017-06-28 04:09:45 +00:00
|
|
|
PMU_OS =0,
|
2017-06-21 00:00:20 +00:00
|
|
|
PMU_WLAN_DEVICE =1,
|
|
|
|
PMU_LOGUART_DEVICE =2,
|
|
|
|
PMU_SDIO_DEVICE =3,
|
|
|
|
|
2017-06-28 04:09:45 +00:00
|
|
|
PMU_UART0_DEVICE =4,
|
|
|
|
PMU_UART1_DEVICE =5,
|
2017-06-21 00:00:20 +00:00
|
|
|
PMU_I2C0_DEVICE =6,
|
|
|
|
PMU_I2C1_DEVICE =7,
|
|
|
|
PMU_USOC_DEVICE =8,
|
|
|
|
PMU_DONGLE_DEVICE =9,
|
|
|
|
PMU_RTC_DEVICE =10,
|
|
|
|
PMU_CONSOL_DEVICE =11,
|
2017-06-28 04:09:45 +00:00
|
|
|
PMU_ADC_DEVICE =12,
|
2017-06-21 00:00:20 +00:00
|
|
|
PMU_DEV_USER_BASE =16,
|
|
|
|
|
|
|
|
PMU_MAX =31
|
|
|
|
} PMU_DEVICE;
|
|
|
|
|
|
|
|
enum SLEEP_TYPE {
|
|
|
|
SLEEP_PG = 0,
|
|
|
|
SLEEP_CG = 1,
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// default locked by OS and not to sleep until OS release wakelock in somewhere
|
|
|
|
#define DEFAULT_WAKELOCK (BIT(PMU_OS))
|
|
|
|
|
|
|
|
typedef uint32_t (*PSM_HOOK_FUN)( unsigned int, void* param_ptr );
|
|
|
|
|
|
|
|
/** Acquire wakelock
|
|
|
|
*
|
|
|
|
* A wakelock is a 32-bit map. Each module own 1 bit in this bit map.
|
|
|
|
* FreeRTOS tickless reference the wakelock and decide that if it can or cannot enter sleep state.
|
|
|
|
* If any module acquire and hold a bit in wakelock, then the whole system won't enter sleep state.
|
|
|
|
*
|
|
|
|
* If wakelock is not equals to 0, then the system won't enter sleep.
|
|
|
|
*
|
|
|
|
* @param nDeviceId : The bit which is attempt to add into wakelock
|
|
|
|
*/
|
2017-06-28 04:09:45 +00:00
|
|
|
//void pmu_acquire_wakelock(uint32_t nDeviceId);
|
|
|
|
void acquire_wakelock(uint32_t flg);
|
|
|
|
#define pmu_acquire_wakelock(nDeviceId) acquire_wakelock(1<<(nDeviceId))
|
2017-06-21 00:00:20 +00:00
|
|
|
|
|
|
|
/** Release wakelock
|
|
|
|
*
|
|
|
|
* If wakelock equals to 0, then the system may enter sleep state if it is in idle state.
|
|
|
|
*
|
|
|
|
* @param nDeviceId : The bit which is attempt to remove from wakelock
|
|
|
|
*/
|
2017-06-28 04:09:45 +00:00
|
|
|
//void pmu_release_wakelock(uint32_t nDeviceId);
|
|
|
|
void release_wakelock(uint32_t flg);
|
|
|
|
#define pmu_release_wakelock(nDeviceId) release_wakelock(1<<(nDeviceId))
|
2017-06-21 00:00:20 +00:00
|
|
|
|
|
|
|
/** Get current wakelock bit map value
|
|
|
|
*
|
|
|
|
* @return : the current wakelock bit map value
|
|
|
|
*/
|
2017-06-28 04:09:45 +00:00
|
|
|
//uint32_t pmu_get_wakelock_status(void);
|
|
|
|
uint32_t get_wakelock_status(void);
|
|
|
|
#define pmu_get_wakelock_status get_wakelock_status
|
2017-06-21 00:00:20 +00:00
|
|
|
|
|
|
|
#if (configGENERATE_RUN_TIME_STATS == 1)
|
|
|
|
|
|
|
|
/** enable to keep wakelock stats
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void pmu_enable_wakelock_stats( unsigned char enable );
|
|
|
|
|
|
|
|
/** Get text report that contain the statics of wakelock holding time
|
|
|
|
*
|
|
|
|
* Each time a module acquries or releases wakelock, a holding time is calculated and sum up to a table.
|
|
|
|
* It is for debug that which module is power saving killer.
|
|
|
|
*
|
|
|
|
* @param pcWriteBuffer : The char buffer that contain the report
|
|
|
|
*/
|
|
|
|
void pmu_get_wakelock_hold_stats( char *pcWriteBuffer );
|
|
|
|
|
|
|
|
/** Recalculate the wakelock statics
|
|
|
|
*
|
|
|
|
* By default the wakelock statics is calculated from system boot up.
|
|
|
|
* If we want to debug power saving killer from a specified timestamp, we can reset the statics.
|
|
|
|
*/
|
|
|
|
void pmu_clean_wakelock_stat(void);
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief set system active time, system can not sleep beore timeout.
|
|
|
|
* @param nDeviceId: PMU_DEVICE
|
|
|
|
* @param timeout: system can not sleep beore timeout, unit is ms.
|
|
|
|
* @retval status value:
|
|
|
|
* - 0: _FAIL
|
|
|
|
* - 1: _SUCCESS
|
|
|
|
*/
|
|
|
|
uint32_t pmu_set_sysactive_time(uint32_t nDeviceId, uint32_t timeout);
|
|
|
|
|
|
|
|
void pmu_add_wakeup_event(uint32_t event);
|
|
|
|
void pmu_del_wakeup_event(uint32_t event);
|
|
|
|
|
|
|
|
void pmu_register_sleep_callback(uint32_t nDeviceId, PSM_HOOK_FUN sleep_hook_fun, void* sleep_param_ptr, PSM_HOOK_FUN wakeup_hook_fun, void* wakeup_param_ptr);
|
|
|
|
void pmu_unregister_sleep_callback(uint32_t nDeviceId);
|
|
|
|
|
|
|
|
#ifdef CONFIG_PLATFORM_8195A
|
|
|
|
/** Set PLL reserved or not when sleep is called
|
|
|
|
*
|
|
|
|
* @param reserve: true for sleep with PLL reserve
|
|
|
|
*/
|
|
|
|
void pmu_set_pll_reserved(unsigned char reserve);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|