app_power.c 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. #include "app_power.h"
  2. #include "nrf_gpio.h"
  3. #include "usr_config.h"
  4. #include "bsp_time.h"
  5. #include "system.h"
  6. #include "hal_mt.h"
  7. #include "hal_battery.h"
  8. #include "app_charge.h"
  9. #include "hal_ble_client.h"
  10. #include "nrf_delay.h"
  11. #include "app_flash.h"
  12. #include "bsp_wdt.h"
  13. #include "app_timer.h"
  14. #include "system.h"
  15. #include "bsp_pwm.h"
  16. #include "app_client.h"
  17. #include "hal_ble_uart0.h"
  18. #include "hal_led.h"
  19. #include "lsm6ds3tr_c.h"
  20. #include "hal_ser_imu_mode_manage.h"
  21. #include "app_math.h"
  22. /********************** 变量区 *************************/
  23. /********************** 函数声明区 *************************/
  24. static void PWR_Off(void)
  25. {
  26. UART0_unInit(PIN_TXD_BLE,PIN_RXD_BLE);
  27. LED_Close_Enforce();
  28. hal_ser_imu_mode_manage_set_required(HAL_SER_IMU_MODE_MANAGE_STANDBY, HAL_SER_IMU_MODE_MANAGE_IMU_MODE_OFF);
  29. hal_ser_imu_mode_manage_set_required(HAL_SER_IMU_MODE_MANAGE_NORMAL, HAL_SER_IMU_MODE_MANAGE_IMU_MODE_OFF);
  30. hal_ser_imu_mode_manage_set_required(HAL_SER_IMU_MODE_MANAGE_SELF_CHECK, HAL_SER_IMU_MODE_MANAGE_IMU_MODE_OFF);
  31. hal_ser_imu_mode_manage_set_required(HAL_SER_IMU_MODE_MANAGE_GAME, HAL_SER_IMU_MODE_MANAGE_IMU_MODE_OFF);
  32. hal_ser_imu_mode_manage_set_required(HAL_SER_IMU_MODE_MANAGE_REALSTEP, HAL_SER_IMU_MODE_MANAGE_IMU_MODE_OFF);
  33. drv_lsm_power_off();
  34. drv_qmc6310_power_off();
  35. nrf_gpio_pin_write(PIN_MT_EN,0);
  36. nrf_delay_ms(200);
  37. nrf_gpio_cfg_sense_input(PIN_CHARGING, NRF_GPIO_PIN_NOPULL, NRF_GPIO_PIN_SENSE_HIGH);//IO
  38. uint32_t err_code = sd_power_system_off();
  39. DEBUG_LOG("power off...BAT:%d,ERR:%d\n",GetBatteryPersent(),err_code);
  40. //APP_ERROR_CHECK(err_code);
  41. }
  42. static void PWR_Process(void)
  43. {
  44. if((0 == GetBatteryPersent() && app_charge_Getstate()==BLE_CHARGE_PULLOUT)){
  45. DEBUG_LOG("BatteryPersent:%d\n",GetBatteryPersent());
  46. DEBUG_LOG("power off...\n");
  47. //保存数据到flash
  48. if(Flash_SaveStep() != ZONE_OP_SUCCESS)Except_TxError(EXCEPT_Power,"save step fail");
  49. extern battercb_t battery_record;
  50. extern void printbatter_cb(battercb_t *c,unsigned char *buff);
  51. memcpy(mFlash.batter,&battery_record,sizeof(battercb_t));
  52. mFlash.RestartCnt =0;
  53. if(Flash_SaveInfomation() != ZONE_OP_SUCCESS)Except_TxError(EXCEPT_Power,"save information fail");
  54. MT_Run(1000);
  55. feed_watchdog();
  56. for(uint8_t temp = 0;temp < 10; temp++){
  57. app_client_DataUpdate_Send();
  58. nrf_delay_ms(100);
  59. }
  60. PWR_Off();
  61. }
  62. }
  63. void PWR_Init(void)
  64. {
  65. Process_Start(10000,"PWR_Process",PWR_Process);
  66. }