|
@@ -16,52 +16,26 @@
|
|
|
|
|
|
#ifdef RT_USING_PM
|
|
|
|
|
|
-static void _drv_pm_enter(struct rt_pm *pm)
|
|
|
+static void _drv_pm_enter(struct rt_pm *pm, uint8_t mode)
|
|
|
{
|
|
|
- rt_uint32_t mode;
|
|
|
-
|
|
|
- mode = pm->current_mode;
|
|
|
-
|
|
|
switch (mode)
|
|
|
{
|
|
|
- case PM_RUN_MODE_NORMAL:
|
|
|
+ case PM_SLEEP_MODE_NONE:
|
|
|
break;
|
|
|
|
|
|
- case PM_SLEEP_MODE_SLEEP:
|
|
|
+ case PM_SLEEP_MODE_IDLE:
|
|
|
__WFI();
|
|
|
break;
|
|
|
|
|
|
- case PM_SLEEP_MODE_TIMER:
|
|
|
- pmu_stop2_enter();
|
|
|
- break;
|
|
|
-
|
|
|
- case PM_SLEEP_MODE_SHUTDOWN:
|
|
|
- pmu_standby_enter(PMU_STANDBY_PORT_NONE);
|
|
|
- break;
|
|
|
-
|
|
|
- default:
|
|
|
- RT_ASSERT(0);
|
|
|
- break;
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-static void _drv_pm_exit(struct rt_pm *pm)
|
|
|
-{
|
|
|
- rt_uint32_t mode;
|
|
|
-
|
|
|
- RT_ASSERT(pm != RT_NULL);
|
|
|
-
|
|
|
- mode = pm->current_mode;
|
|
|
-
|
|
|
- switch (mode)
|
|
|
- {
|
|
|
- case PM_RUN_MODE_NORMAL:
|
|
|
+ case PM_SLEEP_MODE_LIGHT:
|
|
|
break;
|
|
|
|
|
|
- case PM_SLEEP_MODE_SLEEP:
|
|
|
+ case PM_SLEEP_MODE_DEEP:
|
|
|
+ pmu_stop2_enter();
|
|
|
break;
|
|
|
|
|
|
- case PM_SLEEP_MODE_TIMER:
|
|
|
+ case PM_SLEEP_MODE_STANDBY:
|
|
|
+ pmu_standby_enter(PMU_STANDBY_PORT_NONE);
|
|
|
break;
|
|
|
|
|
|
case PM_SLEEP_MODE_SHUTDOWN:
|
|
@@ -73,32 +47,21 @@ static void _drv_pm_exit(struct rt_pm *pm)
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-#if PM_RUN_MODE_COUNT > 1
|
|
|
-static void _drv_pm_frequency_change(struct rt_pm *pm, rt_uint32_t frequency)
|
|
|
-{
|
|
|
- return;
|
|
|
-}
|
|
|
-#endif
|
|
|
-
|
|
|
static int drv_hw_pm_init(void)
|
|
|
{
|
|
|
static const struct rt_pm_ops _ops =
|
|
|
{
|
|
|
_drv_pm_enter,
|
|
|
- _drv_pm_exit,
|
|
|
-
|
|
|
-#if PM_RUN_MODE_COUNT > 1
|
|
|
- _drv_pm_frequency_change,
|
|
|
-#endif
|
|
|
+ RT_NULL,
|
|
|
RT_NULL,
|
|
|
RT_NULL,
|
|
|
RT_NULL
|
|
|
};
|
|
|
|
|
|
- rt_uint8_t timer_mask;
|
|
|
+ rt_uint8_t timer_mask = 0;
|
|
|
|
|
|
- /* initialize timer mask */
|
|
|
- timer_mask = 1UL << PM_SLEEP_MODE_TIMER;
|
|
|
+ /* initialize timer mask(no need tickless) */
|
|
|
+ // timer_mask = 1UL << PM_SLEEP_MODE_DEEP;
|
|
|
|
|
|
/* initialize system pm module */
|
|
|
rt_system_pm_init(&_ops, timer_mask, RT_NULL);
|