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.

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