You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

117 lines
4.4 KiB

1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
  1. #pragma once
  2. #include <stdint.h>
  3. #include <string.h>
  4. #include <time.h>
  5. //
  6. #include "app_scheduler.h"
  7. #include "app_timer.h"
  8. #include "app_uart.h"
  9. #include "app_util_platform.h"
  10. #include "ble_advdata.h"
  11. #include "ble_advertising.h"
  12. #include "ble_conn_params.h"
  13. #include "ble_hci.h"
  14. #include "ble_nus.h"
  15. #include "bsp_btn_ble.h"
  16. #include "diskio_blkdev.h"
  17. #include "ff.h"
  18. #include "nordic_common.h"
  19. #include "nrf.h"
  20. #include "nrf_ble_gatt.h"
  21. #include "nrf_ble_qwr.h"
  22. #include "nrf_block_dev_sdc.h"
  23. #include "nrf_delay.h"
  24. #include "nrf_drv_pwm.h"
  25. #include "nrf_drv_saadc.h"
  26. #include "nrf_drv_spi.h"
  27. #include "nrf_drv_twi.h"
  28. #include "nrf_drv_wdt.h"
  29. #include "nrf_gpio.h"
  30. #include "nrf_log.h"
  31. #include "nrf_log_ctrl.h"
  32. #include "nrf_log_default_backends.h"
  33. #include "nrf_pwr_mgmt.h"
  34. #include "nrf_sdh.h"
  35. #include "nrf_sdh_ble.h"
  36. #include "nrf_sdh_soc.h"
  37. //
  38. #define APP_BLE_CONN_CFG_TAG 1 /**< A tag identifying the SoftDevice BLE configuration. */
  39. // #define ZNORDIC_SCHED_INIT(EVENT_SIZE, QUEUE_SIZE) APP_SCHED_INIT(EVENT_SIZE, QUEUE_SIZE)
  40. /*******************************************************************************
  41. * UTILS *
  42. *******************************************************************************/
  43. typedef struct tm ztm_t;
  44. void wd_init();
  45. void wd_feed();
  46. void znordic_init();
  47. void znordic_loop();
  48. void znrf_gpio_cfg_output(uint32_t pin_number, nrf_gpio_pin_pull_t pull);
  49. int16_t znrf_adc_channel_read_val(uint16_t channel);
  50. void znordic_set_uart_log_pin(uint32_t pin_number);
  51. void znordic_rtc_settime_s(uint32_t timestamp_s);
  52. uint32_t znordic_rtc_gettime_s(void);
  53. uint32_t znordic_getpower_on_s(void); // �����ϵ�ʱ��
  54. uint32_t znordic_getpower_on_ms(void); // ������125ms
  55. uint32_t znordic_haspassed_ms(uint32_t last);
  56. void znordic_rtc_gettime(ztm_t* now);
  57. void znordic_rtc_settime(uint16_t year, uint8_t month, uint8_t day, uint8_t hour, uint8_t min, uint8_t sec);
  58. void znordic_force_flush_log();
  59. const char* fmt(const char* fmt, ...);
  60. const char* hex2str(const uint8_t* data, uint16_t len);
  61. /*******************************************************************************
  62. * LOG *
  63. *******************************************************************************/
  64. #define ZLOGI(...) NRF_LOG_INFO(__VA_ARGS__)
  65. #define ZLOGE(...) NRF_LOG_ERROR(__VA_ARGS__)
  66. #define ZLOGW(...) NRF_LOG_WARNING(__VA_ARGS__)
  67. #define ZLOGD(...) NRF_LOG_DEBUG(__VA_ARGS__)
  68. #define ZLOGI_BLOCK(...) \
  69. { \
  70. NRF_LOG_INFO(__VA_ARGS__); \
  71. znordic_force_flush_log(); \
  72. }
  73. #define ZLOGE_BLOCK(...) \
  74. { \
  75. NRF_LOG_ERROR(__VA_ARGS__); \
  76. znordic_force_flush_log(); \
  77. }
  78. #define ZLOGW_BLOCK(...) \
  79. { \
  80. NRF_LOG_WARNING(__VA_ARGS__); \
  81. znordic_force_flush_log(); \
  82. }
  83. #define ZLOGD_BLOCK(...) \
  84. { \
  85. NRF_LOG_DEBUG(__VA_ARGS__); \
  86. znordic_force_flush_log(); \
  87. }
  88. #define ZARRAY_SIZE(array) (sizeof(array) / sizeof(array[0]))
  89. #define ZPIN(port, num) NRF_GPIO_PIN_MAP(port, num)
  90. #define ZERROR_CHECK(err_code) \
  91. do { \
  92. const uint32_t LOCAL_ERR_CODE = (err_code); \
  93. if (LOCAL_ERR_CODE != NRF_SUCCESS) { \
  94. ZLOGI("%s:%d ZERROR_CHECK(%s) fail:%d", __FILE__, __LINE__, #err_code, LOCAL_ERR_CODE); \
  95. NRF_LOG_PROCESS(); \
  96. APP_ERROR_CHECK(LOCAL_ERR_CODE); \
  97. } \
  98. } while (0)
  99. #define ZASSERT(expr) \
  100. do { \
  101. if (!(expr)) { \
  102. ZLOGI("%s:%d ZASSERT(%s) fail", __FILE__, __LINE__, #expr); \
  103. NRF_LOG_PROCESS(); \
  104. APP_ERROR_CHECK_BOOL(false); \
  105. } \
  106. } while (0)