furi_hal_rtc.h 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  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. FuriHalRtcFlagC2Update = (1 << 3),
  27. } FuriHalRtcFlag;
  28. typedef enum {
  29. FuriHalRtcBootModeNormal = 0, /**< Normal boot mode, default value */
  30. FuriHalRtcBootModeDfu, /**< Boot to DFU (MCU bootloader by ST) */
  31. FuriHalRtcBootModePreUpdate, /**< Boot to Update, pre update */
  32. FuriHalRtcBootModeUpdate, /**< Boot to Update, main */
  33. FuriHalRtcBootModePostUpdate, /**< Boot to Update, post update */
  34. } FuriHalRtcBootMode;
  35. typedef enum {
  36. FuriHalRtcRegisterHeader, /**< RTC structure header */
  37. FuriHalRtcRegisterSystem, /**< Various system bits */
  38. FuriHalRtcRegisterVersion, /**< Pointer to Version */
  39. FuriHalRtcRegisterLfsFingerprint, /**< LFS geometry fingerprint */
  40. FuriHalRtcRegisterFaultData, /**< Pointer to last fault message */
  41. FuriHalRtcRegisterPinFails, /**< Failed pins count */
  42. /* Index of FS directory entry corresponding to FW update to be applied */
  43. FuriHalRtcRegisterUpdateFolderFSIndex,
  44. FuriHalRtcRegisterMAX, /**< Service value, do not use */
  45. } FuriHalRtcRegister;
  46. /** Early initialization */
  47. void furi_hal_rtc_init_early();
  48. /** Early deinitialization */
  49. void furi_hal_rtc_deinit_early();
  50. /** Initialize RTC subsystem */
  51. void furi_hal_rtc_init();
  52. uint32_t furi_hal_rtc_get_register(FuriHalRtcRegister reg);
  53. void furi_hal_rtc_set_register(FuriHalRtcRegister reg, uint32_t value);
  54. void furi_hal_rtc_set_log_level(uint8_t level);
  55. uint8_t furi_hal_rtc_get_log_level();
  56. void furi_hal_rtc_set_flag(FuriHalRtcFlag flag);
  57. void furi_hal_rtc_reset_flag(FuriHalRtcFlag flag);
  58. bool furi_hal_rtc_is_flag_set(FuriHalRtcFlag flag);
  59. void furi_hal_rtc_set_boot_mode(FuriHalRtcBootMode mode);
  60. FuriHalRtcBootMode furi_hal_rtc_get_boot_mode();
  61. void furi_hal_rtc_set_datetime(FuriHalRtcDateTime* datetime);
  62. void furi_hal_rtc_get_datetime(FuriHalRtcDateTime* datetime);
  63. bool furi_hal_rtc_validate_datetime(FuriHalRtcDateTime* datetime);
  64. void furi_hal_rtc_set_fault_data(uint32_t value);
  65. uint32_t furi_hal_rtc_get_fault_data();
  66. void furi_hal_rtc_set_pin_fails(uint32_t value);
  67. uint32_t furi_hal_rtc_get_pin_fails();
  68. uint32_t furi_hal_rtc_datetime_to_timestamp(FuriHalRtcDateTime* datetime);
  69. #ifdef __cplusplus
  70. }
  71. #endif