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.

111 lines
4.2 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. #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 znordic_init();
  45. void znordic_loop();
  46. void znrf_gpio_cfg_output(uint32_t pin_number, nrf_gpio_pin_pull_t pull);
  47. int16_t znrf_adc_channel_read_val(uint16_t channel);
  48. void znordic_rtc_settime_s(uint32_t timestamp_s);
  49. uint32_t znordic_rtc_gettime_s(void);
  50. uint32_t znordic_getpower_on_s(void); // �����ϵ�ʱ��
  51. void znordic_rtc_gettime(ztm_t* now);
  52. void znordic_rtc_settime(uint16_t year, uint8_t month, uint8_t day, uint8_t hour, uint8_t min, uint8_t sec);
  53. void znordic_force_flush_log();
  54. const char* fmt(const char* fmt, ...);
  55. const char* hex2str(const uint8_t* data, uint16_t len);
  56. /*******************************************************************************
  57. * LOG *
  58. *******************************************************************************/
  59. #define ZLOGI(...) NRF_LOG_INFO(__VA_ARGS__)
  60. #define ZLOGE(...) NRF_LOG_ERROR(__VA_ARGS__)
  61. #define ZLOGW(...) NRF_LOG_WARNING(__VA_ARGS__)
  62. #define ZLOGD(...) NRF_LOG_DEBUG(__VA_ARGS__)
  63. #define ZLOGI_BLOCK(...) \
  64. { \
  65. NRF_LOG_INFO(__VA_ARGS__); \
  66. znordic_force_flush_log(); \
  67. }
  68. #define ZLOGE_BLOCK(...) \
  69. { \
  70. NRF_LOG_ERROR(__VA_ARGS__); \
  71. znordic_force_flush_log(); \
  72. }
  73. #define ZLOGW_BLOCK(...) \
  74. { \
  75. NRF_LOG_WARNING(__VA_ARGS__); \
  76. znordic_force_flush_log(); \
  77. }
  78. #define ZLOGD_BLOCK(...) \
  79. { \
  80. NRF_LOG_DEBUG(__VA_ARGS__); \
  81. znordic_force_flush_log(); \
  82. }
  83. #define ZARRAY_SIZE(array) (sizeof(array) / sizeof(array[0]))
  84. #define ZPIN(port, num) NRF_GPIO_PIN_MAP(port, num)
  85. #define ZERROR_CHECK(err_code) \
  86. do { \
  87. const uint32_t LOCAL_ERR_CODE = (err_code); \
  88. if (LOCAL_ERR_CODE != NRF_SUCCESS) { \
  89. ZLOGI("%s:%d ZERROR_CHECK(%s) fail:%d", __FILE__, __LINE__, #err_code, LOCAL_ERR_CODE); \
  90. APP_ERROR_CHECK(LOCAL_ERR_CODE); \
  91. } \
  92. } while (0)
  93. #define ZASSERT(expr) \
  94. do { \
  95. if (!(expr)) { \
  96. ZLOGI("%s:%d ZASSERT(%s) fail", __FILE__, __LINE__, #expr); \
  97. NRF_LOG_PROCESS(); \
  98. app_sched_execute(); \
  99. app_error_handler_bare(0); \
  100. } \
  101. } while (!(expr))