mcu_power_sleep.c 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. #include "mcu_power_sleep.h"
  2. #include "bsp/ml5238.h"
  3. #include "bsp/cs1180.h"
  4. #include "bsp/gpio.h"
  5. #include "bsp/spi.h"
  6. extern void system_clock_24m_irc8m(void);
  7. extern void system_clock_config(void);
  8. static void enable_wakeup_irq(void){
  9. charger_detect_irq_enable(1);
  10. hall_1_detect_irq_enable(1);
  11. hall_2_detect_irq_enable(1);
  12. }
  13. static void disable_wakeup_irq(void){
  14. charger_detect_irq_enable(0);
  15. hall_1_detect_irq_enable(0);
  16. hall_2_detect_irq_enable(0);
  17. }
  18. static void pre_deepsleep(void){
  19. #if (CONFIG_BOARD_TYPE==SHARK_BOARD_SP700)
  20. UART0_IR_EN(0);
  21. UART1_IR_EN(0);
  22. #elif (CONFIG_BOARD_TYPE==SHARK_BOARD_SP600)
  23. RS485_PWR_ENABLE(0);
  24. #endif
  25. CS1180_PWR_ENABLE(0);
  26. //uart0_deinit();
  27. //uart1_deinit();
  28. //gd32_i2c_deinit();
  29. ml5238_power_save(1); //call, before spi0_deinit
  30. spi0_deinit();
  31. spi1_deinit();
  32. system_clock_24m_irc8m();//before dcdc off, should set clock to 24M, avoid ml5238's supply is not enough
  33. DCDC_VOL_OPEN(0);
  34. wdog_start(10);
  35. }
  36. static void post_deepsleep(void){
  37. DCDC_VOL_OPEN(1);
  38. SystemInit();
  39. system_clock_config();
  40. spi0_init();
  41. ml5238_power_save(0);
  42. CS1180_PWR_ENABLE(1);
  43. cs1180_adc_init();
  44. #if (CONFIG_BOARD_TYPE==SHARK_BOARD_SP700)
  45. UART0_IR_EN(1);
  46. UART1_IR_EN(1);
  47. #elif (CONFIG_BOARD_TYPE==SHARK_BOARD_SP600)
  48. RS485_PWR_ENABLE(1);
  49. #endif
  50. //uart0_init();
  51. //uart1_init();
  52. //gd32_i2c_init();
  53. wdog_start(4);
  54. }
  55. void mcu_enter_deepsleep(void){
  56. pre_deepsleep();
  57. enable_wakeup_irq();
  58. pmu_to_deepsleepmode(PMU_LDO_LOWPOWER, WFI_CMD);
  59. disable_wakeup_irq();
  60. post_deepsleep();
  61. }