rtc.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. /*
  2. * Copyright (c) 2021, MediaTek Inc. All rights reserved.
  3. *
  4. * SPDX-License-Identifier: BSD-3-Clause
  5. */
  6. #ifndef RTC_H
  7. #define RTC_H
  8. #define PMIC_RG_SRCLKEN_IN0_HW_MODE_MASK (1U)
  9. #define PMIC_RG_SRCLKEN_IN0_HW_MODE_SHIFT (1U)
  10. #define PMIC_RG_SRCLKEN_IN1_HW_MODE_MASK (1U)
  11. #define PMIC_RG_SRCLKEN_IN1_HW_MODE_SHIFT (3U)
  12. #define PMIC_RG_RTC_EOSC32_CK_PDN_MASK (1U)
  13. #define PMIC_RG_RTC_EOSC32_CK_PDN_SHIFT (2U)
  14. #define PMIC_RG_EOSC_CALI_TD_MASK (7U)
  15. #define PMIC_RG_EOSC_CALI_TD_SHIFT (5U)
  16. #define PMIC_RG_XO_EN32K_MAN_MASK (1U)
  17. #define PMIC_RG_XO_EN32K_MAN_SHIFT (0U)
  18. /* RTC registers */
  19. enum {
  20. RTC_BBPU = 0x0588,
  21. RTC_IRQ_STA = 0x058A,
  22. RTC_IRQ_EN = 0x058C,
  23. RTC_CII_EN = 0x058E
  24. };
  25. enum {
  26. RTC_AL_SEC = 0x05A0,
  27. RTC_AL_MIN = 0x05A2,
  28. RTC_AL_HOU = 0x05A4,
  29. RTC_AL_DOM = 0x05A6,
  30. RTC_AL_DOW = 0x05A8,
  31. RTC_AL_MTH = 0x05AA,
  32. RTC_AL_YEA = 0x05AC,
  33. RTC_AL_MASK = 0x0590
  34. };
  35. enum {
  36. RTC_OSC32CON = 0x05AE,
  37. RTC_CON = 0x05C4,
  38. RTC_WRTGR = 0x05C2
  39. };
  40. enum {
  41. RTC_PDN1 = 0x05B4,
  42. RTC_PDN2 = 0x05B6,
  43. RTC_SPAR0 = 0x05B8,
  44. RTC_SPAR1 = 0x05BA,
  45. RTC_PROT = 0x05BC,
  46. RTC_DIFF = 0x05BE,
  47. RTC_CALI = 0x05C0
  48. };
  49. enum {
  50. RTC_OSC32CON_UNLOCK1 = 0x1A57,
  51. RTC_OSC32CON_UNLOCK2 = 0x2B68
  52. };
  53. enum {
  54. RTC_PROT_UNLOCK1 = 0x586A,
  55. RTC_PROT_UNLOCK2 = 0x9136
  56. };
  57. enum {
  58. RTC_BBPU_PWREN = 1U << 0,
  59. RTC_BBPU_CLR = 1U << 1,
  60. RTC_BBPU_INIT = 1U << 2,
  61. RTC_BBPU_AUTO = 1U << 3,
  62. RTC_BBPU_CLRPKY = 1U << 4,
  63. RTC_BBPU_RELOAD = 1U << 5,
  64. RTC_BBPU_CBUSY = 1U << 6
  65. };
  66. enum {
  67. RTC_AL_MASK_SEC = 1U << 0,
  68. RTC_AL_MASK_MIN = 1U << 1,
  69. RTC_AL_MASK_HOU = 1U << 2,
  70. RTC_AL_MASK_DOM = 1U << 3,
  71. RTC_AL_MASK_DOW = 1U << 4,
  72. RTC_AL_MASK_MTH = 1U << 5,
  73. RTC_AL_MASK_YEA = 1U << 6
  74. };
  75. enum {
  76. RTC_BBPU_AUTO_PDN_SEL = 1U << 6,
  77. RTC_BBPU_2SEC_CK_SEL = 1U << 7,
  78. RTC_BBPU_2SEC_EN = 1U << 8,
  79. RTC_BBPU_2SEC_MODE = 0x3 << 9,
  80. RTC_BBPU_2SEC_STAT_CLEAR = 1U << 11,
  81. RTC_BBPU_2SEC_STAT_STA = 1U << 12
  82. };
  83. enum {
  84. RTC_BBPU_KEY = 0x43 << 8
  85. };
  86. enum {
  87. RTC_EMBCK_SRC_SEL = 1 << 8,
  88. RTC_EMBCK_SEL_MODE = 3 << 6,
  89. RTC_XOSC32_ENB = 1 << 5,
  90. RTC_REG_XOSC32_ENB = 1 << 15
  91. };
  92. enum {
  93. RTC_K_EOSC_RSV_0 = 1 << 8,
  94. RTC_K_EOSC_RSV_1 = 1 << 9,
  95. RTC_K_EOSC_RSV_2 = 1 << 10
  96. };
  97. /* PMIC TOP Register Definition */
  98. enum {
  99. PMIC_RG_TOP_CON = 0x001E,
  100. PMIC_RG_TOP_CKPDN_CON1 = 0x0112,
  101. PMIC_RG_TOP_CKPDN_CON1_SET = 0x0114,
  102. PMIC_RG_TOP_CKPDN_CON1_CLR = 0x0116,
  103. PMIC_RG_TOP_CKSEL_CON0 = 0x0118,
  104. PMIC_RG_TOP_CKSEL_CON0_SET = 0x011A,
  105. PMIC_RG_TOP_CKSEL_CON0_CLR = 0x011C
  106. };
  107. /* PMIC SCK Register Definition */
  108. enum {
  109. PMIC_RG_SCK_TOP_CKPDN_CON0 = 0x051A,
  110. PMIC_RG_SCK_TOP_CKPDN_CON0_SET = 0x051C,
  111. PMIC_RG_SCK_TOP_CKPDN_CON0_CLR = 0x051E,
  112. PMIC_RG_EOSC_CALI_CON0 = 0x540
  113. };
  114. /* PMIC DCXO Register Definition */
  115. enum {
  116. PMIC_RG_DCXO_CW00 = 0x0788,
  117. PMIC_RG_DCXO_CW02 = 0x0790
  118. };
  119. /* external API */
  120. uint16_t RTC_Read(uint32_t addr);
  121. void RTC_Write(uint32_t addr, uint16_t data);
  122. int32_t rtc_busy_wait(void);
  123. int32_t RTC_Write_Trigger(void);
  124. int32_t Writeif_unlock(void);
  125. void rtc_power_off_sequence(void);
  126. #endif /* RTC_H */