furi_hal_rtc.h 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. /**
  2. * @file furi_hal_rtc.h
  3. * Furi Hal RTC API
  4. */
  5. #pragma once
  6. #include <stdint.h>
  7. #include <stdbool.h>
  8. #ifdef __cplusplus
  9. extern "C" {
  10. #endif
  11. typedef struct {
  12. // Time
  13. uint8_t hour; /**< Hour in 24H format: 0-23 */
  14. uint8_t minute; /**< Minute: 0-59 */
  15. uint8_t second; /**< Second: 0-59 */
  16. // Date
  17. uint8_t day; /**< Current day: 1-31 */
  18. uint8_t month; /**< Current month: 1-12 */
  19. uint16_t year; /**< Current year: 2000-2099 */
  20. uint8_t weekday; /**< Current weekday: 1-7 */
  21. } FuriHalRtcDateTime;
  22. typedef enum {
  23. FuriHalRtcFlagDebug = (1 << 0),
  24. FuriHalRtcFlagFactoryReset = (1 << 1),
  25. FuriHalRtcFlagLock = (1 << 2),
  26. } FuriHalRtcFlag;
  27. typedef enum {
  28. FuriHalRtcBootModeNormal = 0, /**< Normal boot mode, default value */
  29. FuriHalRtcBootModeDfu, /**< Boot to DFU (MCU bootloader by ST) */
  30. FuriHalRtcBootModePreUpdate, /**< Boot to Update, pre update */
  31. FuriHalRtcBootModeUpdate, /**< Boot to Update, main */
  32. FuriHalRtcBootModePostUpdate, /**< Boot to Update, post update */
  33. } FuriHalRtcBootMode;
  34. typedef enum {
  35. FuriHalRtcRegisterHeader, /**< RTC structure header */
  36. FuriHalRtcRegisterSystem, /**< Various system bits */
  37. FuriHalRtcRegisterVersion, /**< Pointer to Version */
  38. FuriHalRtcRegisterLfsFingerprint, /**< LFS geometry fingerprint */
  39. FuriHalRtcRegisterFaultData, /**< Pointer to last fault message */
  40. FuriHalRtcRegisterPinFails, /**< Failed pins count */
  41. /* Index of FS directory entry corresponding to FW update to be applied */
  42. FuriHalRtcRegisterUpdateFolderFSIndex,
  43. FuriHalRtcRegisterMAX, /**< Service value, do not use */
  44. } FuriHalRtcRegister;
  45. /** Early initialization */
  46. void furi_hal_rtc_init_early();
  47. /** Early deinitialization */
  48. void furi_hal_rtc_deinit_early();
  49. /** Initialize RTC subsystem */
  50. void furi_hal_rtc_init();
  51. uint32_t furi_hal_rtc_get_register(FuriHalRtcRegister reg);
  52. void furi_hal_rtc_set_register(FuriHalRtcRegister reg, uint32_t value);
  53. void furi_hal_rtc_set_log_level(uint8_t level);
  54. uint8_t furi_hal_rtc_get_log_level();
  55. void furi_hal_rtc_set_flag(FuriHalRtcFlag flag);
  56. void furi_hal_rtc_reset_flag(FuriHalRtcFlag flag);
  57. bool furi_hal_rtc_is_flag_set(FuriHalRtcFlag flag);
  58. void furi_hal_rtc_set_boot_mode(FuriHalRtcBootMode mode);
  59. FuriHalRtcBootMode furi_hal_rtc_get_boot_mode();
  60. void furi_hal_rtc_set_datetime(FuriHalRtcDateTime* datetime);
  61. void furi_hal_rtc_get_datetime(FuriHalRtcDateTime* datetime);
  62. bool furi_hal_rtc_validate_datetime(FuriHalRtcDateTime* datetime);
  63. void furi_hal_rtc_set_fault_data(uint32_t value);
  64. uint32_t furi_hal_rtc_get_fault_data();
  65. void furi_hal_rtc_set_pin_fails(uint32_t value);
  66. uint32_t furi_hal_rtc_get_pin_fails();
  67. #ifdef __cplusplus
  68. }
  69. #endif