rtc.h 2.8 KB

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