drv_rtc.c 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. /*
  2. * Copyright (c) 2006-2024, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2024-02-06 Yilin Sun Initial version.
  9. */
  10. #include <rtthread.h>
  11. #include <rtdevice.h>
  12. #include <sys/time.h>
  13. #include "drv_rtc.h"
  14. #include "fsl_common.h"
  15. #include "fsl_irtc.h"
  16. #ifdef RT_USING_RTC
  17. static rt_err_t mcx_rtc_init(rt_device_t dev)
  18. {
  19. irtc_config_t rtc_cfg;
  20. IRTC_GetDefaultConfig(&rtc_cfg);
  21. //rtc_cfg.clockSelect = kIRTC_Clk32K;
  22. if (IRTC_Init(RTC0, &rtc_cfg) != kStatus_Success)
  23. {
  24. return -RT_EIO;
  25. }
  26. return RT_EOK;
  27. }
  28. static rt_err_t mcx_rtc_get_time(time_t *ts)
  29. {
  30. struct tm tm_new = {0};
  31. irtc_datetime_t rtc_date;
  32. IRTC_GetDatetime(RTC0, &rtc_date);
  33. tm_new.tm_sec = rtc_date.second;
  34. tm_new.tm_min = rtc_date.minute;
  35. tm_new.tm_hour = rtc_date.hour;
  36. tm_new.tm_mday = rtc_date.day;
  37. tm_new.tm_mon = rtc_date.month - 1;
  38. tm_new.tm_year = rtc_date.year - 1900;
  39. *ts = timegm(&tm_new);
  40. return RT_EOK;
  41. }
  42. static rt_err_t mcx_rtc_set_time(time_t *ts)
  43. {
  44. struct tm now;
  45. irtc_datetime_t rtc_date;
  46. gmtime_r(ts, &now);
  47. rtc_date.second = now.tm_sec ;
  48. rtc_date.minute = now.tm_min ;
  49. rtc_date.hour = now.tm_hour;
  50. rtc_date.weekDay = now.tm_wday;
  51. rtc_date.day = now.tm_mday;
  52. rtc_date.month = now.tm_mon + 1;
  53. rtc_date.year = now.tm_year + 1900;
  54. IRTC_SetWriteProtection(RTC0, false);
  55. IRTC_SetDatetime(RTC0, &rtc_date);
  56. return RT_EOK;
  57. }
  58. static rt_err_t mcx_rtc_control(rt_device_t dev, int cmd, void *args)
  59. {
  60. switch (cmd)
  61. {
  62. case RT_DEVICE_CTRL_RTC_GET_TIME:
  63. mcx_rtc_get_time((time_t *)args);
  64. break;
  65. case RT_DEVICE_CTRL_RTC_SET_TIME:
  66. mcx_rtc_set_time((time_t *)args);
  67. break;
  68. case RT_DEVICE_CTRL_RTC_SET_ALARM:
  69. /* TODO: Implement alarm features */
  70. default:
  71. return -RT_EINVAL;
  72. }
  73. return RT_EOK;
  74. }
  75. static struct rt_device device =
  76. {
  77. .type = RT_Device_Class_RTC,
  78. .init = mcx_rtc_init,
  79. .open = RT_NULL,
  80. .close = RT_NULL,
  81. .read = RT_NULL,
  82. .write = RT_NULL,
  83. .control = mcx_rtc_control,
  84. };
  85. int rt_hw_rtc_init(void)
  86. {
  87. rt_err_t ret = RT_EOK;
  88. ret = rt_device_register(&device, "rtc", RT_DEVICE_FLAG_RDWR);
  89. if (ret != RT_EOK)
  90. {
  91. return ret;
  92. }
  93. return RT_EOK;
  94. }
  95. INIT_DEVICE_EXPORT(rt_hw_rtc_init);
  96. #endif /*RT_USING_RTC */