sleep_timer.c 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. // From module: RTC - Real Time Counter in Count Mode (Polled APIs)
  2. #include <rtc_count.h>
  3. #include <rtc_count_interrupt.h>
  4. // #include <rtc_tamper.h>
  5. #include <power.h>
  6. #include <port.h>
  7. #include <rtthread.h>
  8. /* RTC module instance */
  9. static struct rtc_module rtc_instance;
  10. static void _rtc_timer_int_cb(void)
  11. {
  12. port_pin_toggle_output_level(PIN_PB30);
  13. }
  14. /* Init RTC as ADC sample timer */
  15. static void _rtc_timer_init(void)
  16. {
  17. struct rtc_count_config conf;
  18. rtc_count_get_config_defaults(&conf);
  19. conf.prescaler = RTC_COUNT_PRESCALER_DIV_1;
  20. conf.mode = RTC_COUNT_MODE_32BIT;
  21. conf.clear_on_match = false;
  22. conf.compare_values[0] = 0;
  23. // struct rtc_count_events evconfig;
  24. // evconfig.generate_event_on_compare[0] = true;
  25. rtc_count_init(&rtc_instance, RTC, &conf);
  26. // rtc_count_enable_events(&rtc_instance, &evconfig);
  27. // rtc_count_enable(&rtc_instance);
  28. rtc_count_set_count(&rtc_instance, 0);
  29. rtc_count_register_callback(&rtc_instance, _rtc_timer_int_cb, RTC_COUNT_CALLBACK_COMPARE_0);
  30. // rtc_count_enable_callback(&rtc_instance, RTC_COUNT_CALLBACK_COMPARE_0);
  31. }
  32. static void _rtc_timer_start(uint32_t ms)
  33. {
  34. uint32_t compare = 0;
  35. compare = (uint32_t)(32.768 * ms);
  36. // rtc_count_register_callback(&rtc_instance, _rtc_timer_int_cb, RTC_COUNT_CALLBACK_COMPARE_0);
  37. rtc_count_enable_callback(&rtc_instance, RTC_COUNT_CALLBACK_COMPARE_0);
  38. rtc_count_set_count(&rtc_instance, 0);
  39. rtc_count_set_compare(&rtc_instance, compare, RTC_COUNT_COMPARE_0);
  40. rtc_count_enable(&rtc_instance);
  41. }
  42. static void sleep_tick_adjust(uint32_t ms)
  43. {
  44. uint32_t diff;
  45. diff = rt_tick_from_millisecond(ms);
  46. rt_tick_set(rt_tick_get() + diff);
  47. {
  48. struct rt_thread *thread;
  49. /* check time slice */
  50. thread = rt_thread_self();
  51. if (thread->remaining_tick <= diff)
  52. {
  53. /* change to initialized tick */
  54. thread->remaining_tick = thread->init_tick;
  55. /* yield */
  56. rt_thread_yield();
  57. }
  58. else
  59. {
  60. thread->remaining_tick -= diff;
  61. }
  62. /* check timer */
  63. rt_timer_check();
  64. }
  65. }
  66. static void _sleep_entry(void)
  67. {
  68. rt_tick_t timeout;
  69. rt_uint32_t ms;
  70. rt_uint32_t count;
  71. system_set_sleepmode(SYSTEM_SLEEPMODE_STANDBY);
  72. timeout = rt_timer_next_timeout_tick() - rt_tick_get();
  73. ms = timeout * (1000 / RT_TICK_PER_SECOND);
  74. rt_kprintf("os tick:%u entry sleep:%u tick\r\n", rt_tick_get(), timeout);
  75. _rtc_timer_start(ms);
  76. system_sleep();
  77. rt_enter_critical();
  78. count = rtc_count_get_count(&rtc_instance);
  79. ms = (count + 32) / 32.768;
  80. rtc_count_disable(&rtc_instance);
  81. sleep_tick_adjust(ms);
  82. timeout = rt_tick_get();
  83. rt_exit_critical();
  84. rt_kprintf("sleep exited, os tick:%u\n", timeout);
  85. }
  86. void sleep_timer_init(void)
  87. {
  88. _rtc_timer_init();
  89. rt_thread_idle_sethook(_sleep_entry);
  90. }
  91. void sleep_timer_start(uint32_t ms)
  92. {
  93. _rtc_timer_start(ms);
  94. }
  95. void sleep_timer_stop(void)
  96. {
  97. rtc_count_disable(&rtc_instance);
  98. }