summaryrefslogtreecommitdiff
path: root/src/soc/mediatek
diff options
context:
space:
mode:
authorRex-BC Chen <rex-bc.chen@mediatek.com>2022-07-27 15:11:25 +0800
committerPaul Fagerburg <pfagerburg@chromium.org>2022-07-29 15:04:27 +0000
commit9f81a8fc08aa86e307132aee42c3178c3eab8b62 (patch)
tree12d7154a5eee901cd9046d5f51df13209b03bb6b /src/soc/mediatek
parentfeb573e395ea6e82088fe15b4c34afb974a15249 (diff)
soc/mediatek: Move common definitions from rtc.h to rtc_reg_common.h
Move the common definitions to rtc_reg_common.h, so we can reuse those definitions on MT8188. TEST=build pass BUG=b:233720142 Signed-off-by: Bo-Chen Chen <rex-bc.chen@mediatek.com> Change-Id: Ia1d916a88b7cb875b35ee5813b7b52d9e98f5009 Reviewed-on: https://review.coreboot.org/c/coreboot/+/66180 Reviewed-by: Yidi Lin <yidilin@chromium.org> Reviewed-by: Yu-Ping Wu <yupingso@google.com> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Diffstat (limited to 'src/soc/mediatek')
-rw-r--r--src/soc/mediatek/common/include/soc/rtc_reg_common.h134
-rw-r--r--src/soc/mediatek/mt8183/include/soc/rtc.h176
-rw-r--r--src/soc/mediatek/mt8186/include/soc/rtc.h127
-rw-r--r--src/soc/mediatek/mt8192/include/soc/rtc.h127
-rw-r--r--src/soc/mediatek/mt8195/include/soc/rtc.h127
5 files changed, 163 insertions, 528 deletions
diff --git a/src/soc/mediatek/common/include/soc/rtc_reg_common.h b/src/soc/mediatek/common/include/soc/rtc_reg_common.h
new file mode 100644
index 0000000000..88a43e35ec
--- /dev/null
+++ b/src/soc/mediatek/common/include/soc/rtc_reg_common.h
@@ -0,0 +1,134 @@
+/* SPDX-License-Identifier: GPL-2.0-only */
+
+#ifndef SOC_MEDIATEK_RTC_REG_COMMON_H
+#define SOC_MEDIATEK_RTC_REG_COMMON_H
+
+/* RTC registers */
+enum {
+ RTC_BBPU = 0x0588,
+ RTC_IRQ_STA = 0x058A,
+ RTC_IRQ_EN = 0x058C,
+ RTC_CII_EN = 0x058E,
+};
+
+enum {
+ RTC_TC_SEC = 0x0592,
+ RTC_TC_MIN = 0x0594,
+ RTC_TC_HOU = 0x0596,
+ RTC_TC_DOM = 0x0598,
+ RTC_TC_DOW = 0x059A,
+ RTC_TC_MTH = 0x059C,
+ RTC_TC_YEA = 0x059E,
+};
+
+enum {
+ RTC_AL_SEC = 0x05A0,
+ RTC_AL_MIN = 0x05A2,
+ RTC_AL_HOU = 0x05A4,
+ RTC_AL_DOM = 0x05A6,
+ RTC_AL_DOW = 0x05A8,
+ RTC_AL_MTH = 0x05AA,
+ RTC_AL_YEA = 0x05AC,
+ RTC_AL_MASK = 0x0590,
+};
+
+enum {
+ RTC_OSC32CON = 0x05AE,
+ RTC_CON = 0x05C4,
+ RTC_WRTGR = 0x05C2,
+};
+
+enum {
+ RTC_POWERKEY1 = 0x05B0,
+ RTC_POWERKEY2 = 0x05B2,
+};
+
+enum {
+ RTC_PDN1 = 0x05B4,
+ RTC_PDN2 = 0x05B6,
+ RTC_SPAR0 = 0x05B8,
+ RTC_SPAR1 = 0x05BA,
+ RTC_PROT = 0x05BC,
+ RTC_DIFF = 0x05BE,
+ RTC_CALI = 0x05C0,
+};
+
+enum {
+ RTC_CON_VBAT_LPSTA_RAW = 1U << 0,
+ RTC_CON_EOSC32_LPEN = 1U << 1,
+ RTC_CON_XOSC32_LPEN = 1U << 2,
+ RTC_CON_LPRST = 1U << 3,
+ RTC_CON_CDBO = 1U << 4,
+ RTC_CON_F32KOB = 1U << 5,
+ RTC_CON_GPO = 1U << 6,
+ RTC_CON_GOE = 1U << 7,
+ RTC_CON_GSR = 1U << 8,
+ RTC_CON_GSMT = 1U << 9,
+ RTC_CON_GPEN = 1U << 10,
+ RTC_CON_GPU = 1U << 11,
+ RTC_CON_GE4 = 1U << 12,
+ RTC_CON_GE8 = 1U << 13,
+ RTC_CON_GPI = 1U << 14,
+ RTC_CON_LPSTA_RAW = 1U << 15,
+};
+
+enum {
+ RTC_LPD_OPT_XOSC_AND_EOSC_LPD = 0U << 13,
+ RTC_LPD_OPT_EOSC_LPD = 1U << 13,
+ RTC_LPD_OPT_XOSC_LPD = 2U << 13,
+ RTC_LPD_OPT_F32K_CK_ALIVE = 3U << 13,
+ RTC_LPD_OPT_MASK = 3U << 13,
+};
+
+/* PMIC TOP Register Definition */
+enum {
+ PMIC_RG_SCK_TOP_CON0 = 0x050C,
+};
+
+/* PMIC TOP Register Definition */
+enum {
+ PMIC_RG_TOP_CKPDN_CON0 = 0x010C,
+ PMIC_RG_TOP_CKPDN_CON0_SET = 0x010E,
+ PMIC_RG_TOP_CKPDN_CON0_CLR = 0x0110,
+ PMIC_RG_TOP_CKPDN_CON1 = 0x0112,
+ PMIC_RG_TOP_CKPDN_CON1_SET = 0x0114,
+ PMIC_RG_TOP_CKPDN_CON1_CLR = 0x0116,
+ PMIC_RG_TOP_CKSEL_CON0 = 0x0118,
+ PMIC_RG_TOP_CKSEL_CON0_SET = 0x011A,
+ PMIC_RG_TOP_CKSEL_CON0_CLR = 0x011C,
+};
+
+enum {
+ PMIC_RG_FQMTR_32K_CK_PDN_SHIFT = 10,
+ PMIC_RG_FQMTR_CK_PDN_SHIFT = 11,
+};
+
+enum {
+ PMIC_FQMTR_RST_SHIFT = 8,
+};
+
+enum {
+ PMIC_FQMTR_CON0_XOSC32_CK = 0U << 0,
+ PMIC_FQMTR_CON0_DCXO_F32K_CK = 1U << 0,
+ PMIC_FQMTR_CON0_EOSC32_CK = 2U << 0,
+ PMIC_FQMTR_CON0_XOSC32_CK_DETECTON = 3U << 0,
+ PMIC_FQMTR_CON0_FQM26M_CK = 4U << 0,
+ PMIC_FQMTR_CON0_FQM32k_CK = 5U << 0,
+ PMIC_FQMTR_CON0_TEST_CK = 6U << 0,
+ PMIC_FQMTR_CON0_TCKSEL_MASK = 7U << 0,
+ PMIC_FQMTR_CON0_BUSY = 1U << 3,
+ PMIC_FQMTR_CON0_DCXO26M_EN = 1U << 4,
+ PMIC_FQMTR_CON0_FQMTR_EN = 1U << 15,
+};
+
+enum {
+ RTC_FQMTR_LOW_BASE = 794 - 2,
+ RTC_FQMTR_HIGH_BASE = 794 + 2,
+};
+
+enum {
+ RTC_XOSCCALI_START = 0x00,
+ RTC_XOSCCALI_END = 0x1f,
+};
+
+#endif /* SOC_MEDIATEK_RTC_REG_COMMON_H */
diff --git a/src/soc/mediatek/mt8183/include/soc/rtc.h b/src/soc/mediatek/mt8183/include/soc/rtc.h
index 7ca054a940..eb166a32a2 100644
--- a/src/soc/mediatek/mt8183/include/soc/rtc.h
+++ b/src/soc/mediatek/mt8183/include/soc/rtc.h
@@ -5,87 +5,20 @@
#include <soc/pmic_wrap_common.h>
#include <soc/rtc_common.h>
+#include <soc/rtc_reg_common.h>
#include <stdbool.h>
/* RTC registers */
enum {
- RTC_BBPU = 0x0588,
- RTC_IRQ_STA = 0x058A,
- RTC_IRQ_EN = 0x058C,
- RTC_CII_EN = 0x058E
-};
-
-enum {
- RTC_TC_SEC = 0x0592,
- RTC_TC_MIN = 0x0594,
- RTC_TC_HOU = 0x0596,
- RTC_TC_DOM = 0x0598,
- RTC_TC_DOW = 0x059A,
- RTC_TC_MTH = 0x059C,
- RTC_TC_YEA = 0x059E
-};
-
-enum {
- RTC_AL_SEC = 0x05A0,
- RTC_AL_MIN = 0x05A2,
- RTC_AL_HOU = 0x05A4,
- RTC_AL_DOM = 0x05A6,
- RTC_AL_DOW = 0x05A8,
- RTC_AL_MTH = 0x05AA,
- RTC_AL_YEA = 0x05AC,
- RTC_AL_MASK = 0x0590
-};
-
-enum {
- RTC_OSC32CON = 0x05AE,
- RTC_CON = 0x05C4,
- RTC_WRTGR = 0x05C2
-};
-
-enum {
- RTC_POWERKEY1 = 0x05B0,
- RTC_POWERKEY2 = 0x05B2
-};
-
-enum {
- RTC_PDN1 = 0x05B4,
- RTC_PDN2 = 0x05B6,
- RTC_SPAR0 = 0x05B8,
- RTC_SPAR1 = 0x05BA,
- RTC_PROT = 0x05BC,
- RTC_DIFF = 0x05BE,
- RTC_CALI = 0x05C0
-};
+ RTC_BBPU_PWREN = 1U << 0,
+ RTC_BBPU_CLR = 1U << 1,
+ RTC_BBPU_INIT = 1U << 2,
+ RTC_BBPU_AUTO = 1U << 3,
+ RTC_BBPU_CLRPKY = 1U << 4,
+ RTC_BBPU_RELOAD = 1U << 5,
+ RTC_BBPU_CBUSY = 1U << 6,
-enum {
- RTC_BBPU_PWREN = 1U << 0,
- RTC_BBPU_CLR = 1U << 1,
- RTC_BBPU_INIT = 1U << 2,
- RTC_BBPU_AUTO = 1U << 3,
- RTC_BBPU_CLRPKY = 1U << 4,
- RTC_BBPU_RELOAD = 1U << 5,
- RTC_BBPU_CBUSY = 1U << 6,
-
- RTC_CBUSY_TIMEOUT_US = 8000
-};
-
-enum {
- RTC_CON_VBAT_LPSTA_RAW = 1U << 0,
- RTC_CON_EOSC32_LPEN = 1U << 1,
- RTC_CON_XOSC32_LPEN = 1U << 2,
- RTC_CON_LPRST = 1U << 3,
- RTC_CON_CDBO = 1U << 4,
- RTC_CON_F32KOB = 1U << 5,
- RTC_CON_GPO = 1U << 6,
- RTC_CON_GOE = 1U << 7,
- RTC_CON_GSR = 1U << 8,
- RTC_CON_GSMT = 1U << 9,
- RTC_CON_GPEN = 1U << 10,
- RTC_CON_GPU = 1U << 11,
- RTC_CON_GE4 = 1U << 12,
- RTC_CON_GE8 = 1U << 13,
- RTC_CON_GPI = 1U << 14,
- RTC_CON_LPSTA_RAW = 1U << 15
+ RTC_CBUSY_TIMEOUT_US = 8000,
};
enum {
@@ -99,58 +32,28 @@ enum {
RTC_EMBCK_SRC_SEL = 1U << 8,
RTC_EMBCK_SEL_OPTION = 1U << 9,
RTC_GPS_CKOUT_EN = 1U << 10,
- RTC_REG_XOSC32_ENB = 1U << 15
-};
-
-enum {
- RTC_LPD_OPT_XOSC_AND_EOSC_LPD = 0U << 13,
- RTC_LPD_OPT_EOSC_LPD = 1U << 13,
- RTC_LPD_OPT_XOSC_LPD = 2U << 13,
- RTC_LPD_OPT_F32K_CK_ALIVE = 3U << 13,
- RTC_LPD_OPT_MASK = 3U << 13
-};
-
-/* PMIC TOP Register Definition */
-enum {
- PMIC_RG_SCK_TOP_CON0 = 0x050C
-};
-
-/* PMIC TOP Register Definition */
-enum {
- PMIC_RG_TOP_CKPDN_CON0 = 0x010C,
- PMIC_RG_TOP_CKPDN_CON0_SET = 0x010E,
- PMIC_RG_TOP_CKPDN_CON0_CLR = 0x0110,
- PMIC_RG_TOP_CKPDN_CON1 = 0x0112,
- PMIC_RG_TOP_CKPDN_CON1_SET = 0x0114,
- PMIC_RG_TOP_CKPDN_CON1_CLR = 0x0116,
- PMIC_RG_TOP_CKSEL_CON0 = 0x0118,
- PMIC_RG_TOP_CKSEL_CON0_SET = 0x011A,
- PMIC_RG_TOP_CKSEL_CON0_CLR = 0x011C
-};
-
-enum {
- PMIC_RG_FQMTR_32K_CK_PDN_SHIFT = 10,
- PMIC_RG_FQMTR_CK_PDN_SHIFT = 11
+ RTC_REG_XOSC32_ENB = 1U << 15,
};
/* PMIC DCXO Register Definition */
enum {
- PMIC_RG_DCXO_CW00 = 0x0788,
- PMIC_RG_DCXO_CW00_CLR = 0x078C,
- PMIC_RG_DCXO_CW02 = 0x0790,
- PMIC_RG_DCXO_CW07 = 0x079A,
- PMIC_RG_DCXO_CW09 = 0x079E,
- PMIC_RG_DCXO_CW11 = 0x07A2,
- PMIC_RG_DCXO_CW13 = 0x07AA,
- PMIC_RG_DCXO_CW15 = 0x07AE,
- PMIC_RG_DCXO_CW16 = 0x07B0,
- PMIC_RG_DCXO_CW21 = 0x07BA,
- PMIC_RG_DCXO_CW23 = 0x07BE,
- PMIC_RG_DCXO_ELR0 = 0x07C4
+ PMIC_RG_DCXO_CW00 = 0x0788,
+ PMIC_RG_DCXO_CW00_CLR = 0x078C,
+ PMIC_RG_DCXO_CW02 = 0x0790,
+ PMIC_RG_DCXO_CW03 = 0x0794,
+ PMIC_RG_DCXO_CW07 = 0x079A,
+ PMIC_RG_DCXO_CW09 = 0x079E,
+ PMIC_RG_DCXO_CW11 = 0x07A2,
+ PMIC_RG_DCXO_CW13 = 0x07AA,
+ PMIC_RG_DCXO_CW15 = 0x07AE,
+ PMIC_RG_DCXO_CW16 = 0x07B0,
+ PMIC_RG_DCXO_CW21 = 0x07BA,
+ PMIC_RG_DCXO_CW23 = 0x07BE,
+ PMIC_RG_DCXO_ELR0 = 0x07C4,
};
enum {
- PMIC_RG_TOP_TMA_KEY = 0x03A8
+ PMIC_RG_TOP_TMA_KEY = 0x03A8,
};
/* PMIC Frequency Meter Definition */
@@ -161,7 +64,7 @@ enum {
PMIC_RG_FQMTR_WINSET = 0x0516,
PMIC_RG_FQMTR_DATA = 0x0518,
- FQMTR_TIMEOUT_US = 8000
+ FQMTR_TIMEOUT_US = 8000,
};
enum {
@@ -172,36 +75,9 @@ enum {
PMIC_FQMTR_FIX_CLK_SMPS_CK = 4U << 0,
PMIC_FQMTR_FIX_CLK_TCK_SEC = 5U << 0,
PMIC_FQMTR_FIX_CLK_PMU_75K = 6U << 0,
- PMIC_FQMTR_CKSEL_MASK = 7U << 0
+ PMIC_FQMTR_CKSEL_MASK = 7U << 0,
};
-enum {
- PMIC_FQMTR_RST_SHIFT = 8
-};
-
-enum {
- PMIC_FQMTR_CON0_XOSC32_CK = 0U << 0,
- PMIC_FQMTR_CON0_DCXO_F32K_CK = 1U << 0,
- PMIC_FQMTR_CON0_EOSC32_CK = 2U << 0,
- PMIC_FQMTR_CON0_XOSC32_CK_DETECTON = 3U << 0,
- PMIC_FQMTR_CON0_FQM26M_CK = 4U << 0,
- PMIC_FQMTR_CON0_FQM32k_CK = 5U << 0,
- PMIC_FQMTR_CON0_TEST_CK = 6U << 0,
- PMIC_FQMTR_CON0_TCKSEL_MASK = 7U << 0,
- PMIC_FQMTR_CON0_BUSY = 1U << 3,
- PMIC_FQMTR_CON0_DCXO26M_EN = 1U << 4,
- PMIC_FQMTR_CON0_FQMTR_EN = 1U << 15
-};
-
-enum {
- RTC_FQMTR_LOW_BASE = 794 - 2,
- RTC_FQMTR_HIGH_BASE = 794 + 2
-};
-
-enum {
- RTC_XOSCCALI_START = 0x00,
- RTC_XOSCCALI_END = 0x1f
-};
/* external API */
void rtc_bbpu_power_on(void);
diff --git a/src/soc/mediatek/mt8186/include/soc/rtc.h b/src/soc/mediatek/mt8186/include/soc/rtc.h
index a3fb7a099f..914da6ac83 100644
--- a/src/soc/mediatek/mt8186/include/soc/rtc.h
+++ b/src/soc/mediatek/mt8186/include/soc/rtc.h
@@ -10,59 +10,11 @@
#include <soc/pmic_wrap_common.h>
#include <soc/rtc_common.h>
+#include <soc/rtc_reg_common.h>
#include <stdbool.h>
/* RTC registers */
enum {
- RTC_BBPU = 0x0588,
- RTC_IRQ_STA = 0x058A,
- RTC_IRQ_EN = 0x058C,
- RTC_CII_EN = 0x058E,
-};
-
-enum {
- RTC_TC_SEC = 0x0592,
- RTC_TC_MIN = 0x0594,
- RTC_TC_HOU = 0x0596,
- RTC_TC_DOM = 0x0598,
- RTC_TC_DOW = 0x059A,
- RTC_TC_MTH = 0x059C,
- RTC_TC_YEA = 0x059E,
-};
-
-enum {
- RTC_AL_SEC = 0x05A0,
- RTC_AL_MIN = 0x05A2,
- RTC_AL_HOU = 0x05A4,
- RTC_AL_DOM = 0x05A6,
- RTC_AL_DOW = 0x05A8,
- RTC_AL_MTH = 0x05AA,
- RTC_AL_YEA = 0x05AC,
- RTC_AL_MASK = 0x0590,
-};
-
-enum {
- RTC_OSC32CON = 0x05AE,
- RTC_CON = 0x05C4,
- RTC_WRTGR = 0x05C2,
-};
-
-enum {
- RTC_POWERKEY1 = 0x05B0,
- RTC_POWERKEY2 = 0x05B2,
-};
-
-enum {
- RTC_PDN1 = 0x05B4,
- RTC_PDN2 = 0x05B6,
- RTC_SPAR0 = 0x05B8,
- RTC_SPAR1 = 0x05BA,
- RTC_PROT = 0x05BC,
- RTC_DIFF = 0x05BE,
- RTC_CALI = 0x05C0,
-};
-
-enum {
RTC_BBPU_PWREN = 1U << 0,
RTC_BBPU_CLR = 1U << 1,
RTC_BBPU_INIT = 1U << 2,
@@ -75,25 +27,6 @@ enum {
};
enum {
- RTC_CON_VBAT_LPSTA_RAW = 1U << 0,
- RTC_CON_EOSC32_LPEN = 1U << 1,
- RTC_CON_XOSC32_LPEN = 1U << 2,
- RTC_CON_LPRST = 1U << 3,
- RTC_CON_CDBO = 1U << 4,
- RTC_CON_F32KOB = 1U << 5,
- RTC_CON_GPO = 1U << 6,
- RTC_CON_GOE = 1U << 7,
- RTC_CON_GSR = 1U << 8,
- RTC_CON_GSMT = 1U << 9,
- RTC_CON_GPEN = 1U << 10,
- RTC_CON_GPU = 1U << 11,
- RTC_CON_GE4 = 1U << 12,
- RTC_CON_GE8 = 1U << 13,
- RTC_CON_GPI = 1U << 14,
- RTC_CON_LPSTA_RAW = 1U << 15,
-};
-
-enum {
RTC_XOSCCALI_MASK = 0x1F << 0,
RTC_XOSC32_ENB = 1U << 5,
RTC_EMB_HW_MODE = 0U << 6,
@@ -107,37 +40,6 @@ enum {
RTC_REG_XOSC32_ENB = 1U << 15,
};
-enum {
- RTC_LPD_OPT_XOSC_AND_EOSC_LPD = 0U << 13,
- RTC_LPD_OPT_EOSC_LPD = 1U << 13,
- RTC_LPD_OPT_XOSC_LPD = 2U << 13,
- RTC_LPD_OPT_F32K_CK_ALIVE = 3U << 13,
- RTC_LPD_OPT_MASK = 3U << 13,
-};
-
-/* PMIC TOP Register Definition */
-enum {
- PMIC_RG_SCK_TOP_CON0 = 0x050C,
-};
-
-/* PMIC TOP Register Definition */
-enum {
- PMIC_RG_TOP_CKPDN_CON0 = 0x010C,
- PMIC_RG_TOP_CKPDN_CON0_SET = 0x010E,
- PMIC_RG_TOP_CKPDN_CON0_CLR = 0x0110,
- PMIC_RG_TOP_CKPDN_CON1 = 0x0112,
- PMIC_RG_TOP_CKPDN_CON1_SET = 0x0114,
- PMIC_RG_TOP_CKPDN_CON1_CLR = 0x0116,
- PMIC_RG_TOP_CKSEL_CON0 = 0x0118,
- PMIC_RG_TOP_CKSEL_CON0_SET = 0x011A,
- PMIC_RG_TOP_CKSEL_CON0_CLR = 0x011C,
-};
-
-enum {
- PMIC_RG_FQMTR_32K_CK_PDN_SHIFT = 10,
- PMIC_RG_FQMTR_CK_PDN_SHIFT = 11,
-};
-
/* PMIC DCXO Register Definition */
enum {
PMIC_RG_DCXO_CW00 = 0x0788,
@@ -181,33 +83,6 @@ enum {
PMIC_FQMTR_CKSEL_MASK = 7U << 0,
};
-enum {
- PMIC_FQMTR_RST_SHIFT = 8
-};
-
-enum {
- PMIC_FQMTR_CON0_XOSC32_CK = 0U << 0,
- PMIC_FQMTR_CON0_DCXO_F32K_CK = 1U << 0,
- PMIC_FQMTR_CON0_EOSC32_CK = 2U << 0,
- PMIC_FQMTR_CON0_XOSC32_CK_DETECTON = 3U << 0,
- PMIC_FQMTR_CON0_FQM26M_CK = 4U << 0,
- PMIC_FQMTR_CON0_FQM32k_CK = 5U << 0,
- PMIC_FQMTR_CON0_TEST_CK = 6U << 0,
- PMIC_FQMTR_CON0_TCKSEL_MASK = 7U << 0,
- PMIC_FQMTR_CON0_BUSY = 1U << 3,
- PMIC_FQMTR_CON0_DCXO26M_EN = 1U << 4,
- PMIC_FQMTR_CON0_FQMTR_EN = 1U << 15,
-};
-
-enum {
- RTC_FQMTR_LOW_BASE = 794 - 2,
- RTC_FQMTR_HIGH_BASE = 794 + 2,
-};
-
-enum {
- RTC_XOSCCALI_START = 0x00,
- RTC_XOSCCALI_END = 0x1f,
-};
/* external API */
void rtc_bbpu_power_on(void);
diff --git a/src/soc/mediatek/mt8192/include/soc/rtc.h b/src/soc/mediatek/mt8192/include/soc/rtc.h
index 46c06f4a52..f8543ab45d 100644
--- a/src/soc/mediatek/mt8192/include/soc/rtc.h
+++ b/src/soc/mediatek/mt8192/include/soc/rtc.h
@@ -4,59 +4,11 @@
#define SOC_MEDIATEK_MT8192_RTC_H
#include <soc/pmif.h>
+#include <soc/rtc_reg_common.h>
#include <stdbool.h>
/* RTC registers */
enum {
- RTC_BBPU = 0x0588,
- RTC_IRQ_STA = 0x058A,
- RTC_IRQ_EN = 0x058C,
- RTC_CII_EN = 0x058E,
-};
-
-enum {
- RTC_TC_SEC = 0x0592,
- RTC_TC_MIN = 0x0594,
- RTC_TC_HOU = 0x0596,
- RTC_TC_DOM = 0x0598,
- RTC_TC_DOW = 0x059A,
- RTC_TC_MTH = 0x059C,
- RTC_TC_YEA = 0x059E,
-};
-
-enum {
- RTC_AL_SEC = 0x05A0,
- RTC_AL_MIN = 0x05A2,
- RTC_AL_HOU = 0x05A4,
- RTC_AL_DOM = 0x05A6,
- RTC_AL_DOW = 0x05A8,
- RTC_AL_MTH = 0x05AA,
- RTC_AL_YEA = 0x05AC,
- RTC_AL_MASK = 0x0590,
-};
-
-enum {
- RTC_OSC32CON = 0x05AE,
- RTC_CON = 0x05C4,
- RTC_WRTGR = 0x05C2,
-};
-
-enum {
- RTC_POWERKEY1 = 0x05B0,
- RTC_POWERKEY2 = 0x05B2,
-};
-
-enum {
- RTC_PDN1 = 0x05B4,
- RTC_PDN2 = 0x05B6,
- RTC_SPAR0 = 0x05B8,
- RTC_SPAR1 = 0x05BA,
- RTC_PROT = 0x05BC,
- RTC_DIFF = 0x05BE,
- RTC_CALI = 0x05C0,
-};
-
-enum {
RTC_BBPU_ENABLE_ALARM = 1U << 0,
RTC_BBPU_SPAR_SW = 1U << 1,
RTC_BBPU_RESET_SPAR = 1U << 2,
@@ -68,25 +20,6 @@ enum {
};
enum {
- RTC_CON_VBAT_LPSTA_RAW = 1U << 0,
- RTC_CON_EOSC32_LPEN = 1U << 1,
- RTC_CON_XOSC32_LPEN = 1U << 2,
- RTC_CON_LPRST = 1U << 3,
- RTC_CON_CDBO = 1U << 4,
- RTC_CON_F32KOB = 1U << 5,
- RTC_CON_GPO = 1U << 6,
- RTC_CON_GOE = 1U << 7,
- RTC_CON_GSR = 1U << 8,
- RTC_CON_GSMT = 1U << 9,
- RTC_CON_GPEN = 1U << 10,
- RTC_CON_GPU = 1U << 11,
- RTC_CON_GE4 = 1U << 12,
- RTC_CON_GE8 = 1U << 13,
- RTC_CON_GPI = 1U << 14,
- RTC_CON_LPSTA_RAW = 1U << 15,
-};
-
-enum {
RTC_XOSCCALI_MASK = 0x1F << 0,
RTC_XOSC32_ENB = 1U << 5,
RTC_EMB_HW_MODE = 0U << 6,
@@ -110,37 +43,6 @@ enum {
};
enum {
- RTC_LPD_OPT_XOSC_AND_EOSC_LPD = 0U << 13,
- RTC_LPD_OPT_EOSC_LPD = 1U << 13,
- RTC_LPD_OPT_XOSC_LPD = 2U << 13,
- RTC_LPD_OPT_F32K_CK_ALIVE = 3U << 13,
- RTC_LPD_OPT_MASK = 3U << 13,
-};
-
-/* PMIC TOP Register Definition */
-enum {
- PMIC_RG_SCK_TOP_CON0 = 0x050C,
-};
-
-/* PMIC TOP Register Definition */
-enum {
- PMIC_RG_TOP_CKPDN_CON0 = 0x010C,
- PMIC_RG_TOP_CKPDN_CON0_SET = 0x010E,
- PMIC_RG_TOP_CKPDN_CON0_CLR = 0x0110,
- PMIC_RG_TOP_CKPDN_CON1 = 0x0112,
- PMIC_RG_TOP_CKPDN_CON1_SET = 0x0114,
- PMIC_RG_TOP_CKPDN_CON1_CLR = 0x0116,
- PMIC_RG_TOP_CKSEL_CON0 = 0x0118,
- PMIC_RG_TOP_CKSEL_CON0_SET = 0x011A,
- PMIC_RG_TOP_CKSEL_CON0_CLR = 0x011C,
-};
-
-enum {
- PMIC_RG_FQMTR_32K_CK_PDN_SHIFT = 10,
- PMIC_RG_FQMTR_CK_PDN_SHIFT = 11,
-};
-
-enum {
PMIC_RG_BANK_FQMTR_RST = 0x522,
};
@@ -170,33 +72,6 @@ enum {
PMIC_FQMTR_CKSEL_MASK = 7U << 0,
};
-enum {
- PMIC_FQMTR_RST_SHIFT = 8,
-};
-
-enum {
- PMIC_FQMTR_CON0_XOSC32_CK = 0U << 0,
- PMIC_FQMTR_CON0_DCXO_F32K_CK = 1U << 0,
- PMIC_FQMTR_CON0_EOSC32_CK = 2U << 0,
- PMIC_FQMTR_CON0_XOSC32_CK_DETECTON = 3U << 0,
- PMIC_FQMTR_CON0_FQM26M_CK = 4U << 0,
- PMIC_FQMTR_CON0_FQM32k_CK = 5U << 0,
- PMIC_FQMTR_CON0_TEST_CK = 6U << 0,
- PMIC_FQMTR_CON0_TCKSEL_MASK = 7U << 0,
- PMIC_FQMTR_CON0_BUSY = 1U << 3,
- PMIC_FQMTR_CON0_DCXO26M_EN = 1U << 4,
- PMIC_FQMTR_CON0_FQMTR_EN = 1U << 15,
-};
-
-enum {
- RTC_FQMTR_LOW_BASE = 794 - 2,
- RTC_FQMTR_HIGH_BASE = 794 + 2,
-};
-
-enum {
- RTC_XOSCCALI_START = 0x00,
- RTC_XOSCCALI_END = 0x1f,
-};
enum {
RTC_TC_MTH_MASK = 0xf,
diff --git a/src/soc/mediatek/mt8195/include/soc/rtc.h b/src/soc/mediatek/mt8195/include/soc/rtc.h
index 908473166e..6656d313e3 100644
--- a/src/soc/mediatek/mt8195/include/soc/rtc.h
+++ b/src/soc/mediatek/mt8195/include/soc/rtc.h
@@ -4,59 +4,11 @@
#define SOC_MEDIATEK_MT8195_RTC_H
#include <soc/pmif.h>
+#include <soc/rtc_reg_common.h>
#include <stdbool.h>
/* RTC registers */
enum {
- RTC_BBPU = 0x0588,
- RTC_IRQ_STA = 0x058A,
- RTC_IRQ_EN = 0x058C,
- RTC_CII_EN = 0x058E,
-};
-
-enum {
- RTC_TC_SEC = 0x0592,
- RTC_TC_MIN = 0x0594,
- RTC_TC_HOU = 0x0596,
- RTC_TC_DOM = 0x0598,
- RTC_TC_DOW = 0x059A,
- RTC_TC_MTH = 0x059C,
- RTC_TC_YEA = 0x059E,
-};
-
-enum {
- RTC_AL_SEC = 0x05A0,
- RTC_AL_MIN = 0x05A2,
- RTC_AL_HOU = 0x05A4,
- RTC_AL_DOM = 0x05A6,
- RTC_AL_DOW = 0x05A8,
- RTC_AL_MTH = 0x05AA,
- RTC_AL_YEA = 0x05AC,
- RTC_AL_MASK = 0x0590,
-};
-
-enum {
- RTC_OSC32CON = 0x05AE,
- RTC_CON = 0x05C4,
- RTC_WRTGR = 0x05C2,
-};
-
-enum {
- RTC_POWERKEY1 = 0x05B0,
- RTC_POWERKEY2 = 0x05B2,
-};
-
-enum {
- RTC_PDN1 = 0x05B4,
- RTC_PDN2 = 0x05B6,
- RTC_SPAR0 = 0x05B8,
- RTC_SPAR1 = 0x05BA,
- RTC_PROT = 0x05BC,
- RTC_DIFF = 0x05BE,
- RTC_CALI = 0x05C0,
-};
-
-enum {
RTC_BBPU_ENABLE_ALARM = 1U << 0,
RTC_BBPU_SPAR_SW = 1U << 1,
RTC_BBPU_RESET_SPAR = 1U << 2,
@@ -68,25 +20,6 @@ enum {
};
enum {
- RTC_CON_VBAT_LPSTA_RAW = 1U << 0,
- RTC_CON_EOSC32_LPEN = 1U << 1,
- RTC_CON_XOSC32_LPEN = 1U << 2,
- RTC_CON_LPRST = 1U << 3,
- RTC_CON_CDBO = 1U << 4,
- RTC_CON_F32KOB = 1U << 5,
- RTC_CON_GPO = 1U << 6,
- RTC_CON_GOE = 1U << 7,
- RTC_CON_GSR = 1U << 8,
- RTC_CON_GSMT = 1U << 9,
- RTC_CON_GPEN = 1U << 10,
- RTC_CON_GPU = 1U << 11,
- RTC_CON_GE4 = 1U << 12,
- RTC_CON_GE8 = 1U << 13,
- RTC_CON_GPI = 1U << 14,
- RTC_CON_LPSTA_RAW = 1U << 15,
-};
-
-enum {
RTC_XOSCCALI_MASK = 0x1F << 0,
RTC_XOSC32_ENB = 1U << 5,
RTC_EMB_HW_MODE = 0U << 6,
@@ -110,37 +43,6 @@ enum {
};
enum {
- RTC_LPD_OPT_XOSC_AND_EOSC_LPD = 0U << 13,
- RTC_LPD_OPT_EOSC_LPD = 1U << 13,
- RTC_LPD_OPT_XOSC_LPD = 2U << 13,
- RTC_LPD_OPT_F32K_CK_ALIVE = 3U << 13,
- RTC_LPD_OPT_MASK = 3U << 13,
-};
-
-/* PMIC TOP Register Definition */
-enum {
- PMIC_RG_SCK_TOP_CON0 = 0x050C,
-};
-
-/* PMIC TOP Register Definition */
-enum {
- PMIC_RG_TOP_CKPDN_CON0 = 0x010C,
- PMIC_RG_TOP_CKPDN_CON0_SET = 0x010E,
- PMIC_RG_TOP_CKPDN_CON0_CLR = 0x0110,
- PMIC_RG_TOP_CKPDN_CON1 = 0x0112,
- PMIC_RG_TOP_CKPDN_CON1_SET = 0x0114,
- PMIC_RG_TOP_CKPDN_CON1_CLR = 0x0116,
- PMIC_RG_TOP_CKSEL_CON0 = 0x0118,
- PMIC_RG_TOP_CKSEL_CON0_SET = 0x011A,
- PMIC_RG_TOP_CKSEL_CON0_CLR = 0x011C,
-};
-
-enum {
- PMIC_RG_FQMTR_32K_CK_PDN_SHIFT = 10,
- PMIC_RG_FQMTR_CK_PDN_SHIFT = 11,
-};
-
-enum {
PMIC_RG_BANK_FQMTR_RST = 0x522,
};
@@ -170,33 +72,6 @@ enum {
PMIC_FQMTR_CKSEL_MASK = 7U << 0,
};
-enum {
- PMIC_FQMTR_RST_SHIFT = 8,
-};
-
-enum {
- PMIC_FQMTR_CON0_XOSC32_CK = 0U << 0,
- PMIC_FQMTR_CON0_DCXO_F32K_CK = 1U << 0,
- PMIC_FQMTR_CON0_EOSC32_CK = 2U << 0,
- PMIC_FQMTR_CON0_XOSC32_CK_DETECTON = 3U << 0,
- PMIC_FQMTR_CON0_FQM26M_CK = 4U << 0,
- PMIC_FQMTR_CON0_FQM32k_CK = 5U << 0,
- PMIC_FQMTR_CON0_TEST_CK = 6U << 0,
- PMIC_FQMTR_CON0_TCKSEL_MASK = 7U << 0,
- PMIC_FQMTR_CON0_BUSY = 1U << 3,
- PMIC_FQMTR_CON0_DCXO26M_EN = 1U << 4,
- PMIC_FQMTR_CON0_FQMTR_EN = 1U << 15,
-};
-
-enum {
- RTC_FQMTR_LOW_BASE = 794 - 2,
- RTC_FQMTR_HIGH_BASE = 794 + 2,
-};
-
-enum {
- RTC_XOSCCALI_START = 0x00,
- RTC_XOSCCALI_END = 0x1f,
-};
enum {
RTC_TC_MTH_MASK = 0xf,