|
@@ -22,6 +22,7 @@
|
|
|
|
|
|
#include <dt-bindings/power/mt2701-power.h>
|
|
|
#include <dt-bindings/power/mt6797-power.h>
|
|
|
+#include <dt-bindings/power/mt7622-power.h>
|
|
|
#include <dt-bindings/power/mt8173-power.h>
|
|
|
|
|
|
#define SPM_VDE_PWR_CON 0x0210
|
|
@@ -39,6 +40,11 @@
|
|
|
#define SPM_MFG_2D_PWR_CON 0x02c0
|
|
|
#define SPM_MFG_ASYNC_PWR_CON 0x02c4
|
|
|
#define SPM_USB_PWR_CON 0x02cc
|
|
|
+#define SPM_ETHSYS_PWR_CON 0x02e0 /* MT7622 */
|
|
|
+#define SPM_HIF0_PWR_CON 0x02e4 /* MT7622 */
|
|
|
+#define SPM_HIF1_PWR_CON 0x02e8 /* MT7622 */
|
|
|
+#define SPM_WB_PWR_CON 0x02ec /* MT7622 */
|
|
|
+
|
|
|
|
|
|
#define SPM_PWR_STATUS 0x060c
|
|
|
#define SPM_PWR_STATUS_2ND 0x0610
|
|
@@ -64,6 +70,10 @@
|
|
|
#define PWR_STATUS_MFG_ASYNC BIT(23)
|
|
|
#define PWR_STATUS_AUDIO BIT(24)
|
|
|
#define PWR_STATUS_USB BIT(25)
|
|
|
+#define PWR_STATUS_ETHSYS BIT(24) /* MT7622 */
|
|
|
+#define PWR_STATUS_HIF0 BIT(25) /* MT7622 */
|
|
|
+#define PWR_STATUS_HIF1 BIT(26) /* MT7622 */
|
|
|
+#define PWR_STATUS_WB BIT(27) /* MT7622 */
|
|
|
|
|
|
enum clk_id {
|
|
|
CLK_NONE,
|
|
@@ -73,6 +83,7 @@ enum clk_id {
|
|
|
CLK_VENC_LT,
|
|
|
CLK_ETHIF,
|
|
|
CLK_VDEC,
|
|
|
+ CLK_HIFSEL,
|
|
|
CLK_MAX,
|
|
|
};
|
|
|
|
|
@@ -84,6 +95,7 @@ static const char * const clk_names[] = {
|
|
|
"venc_lt",
|
|
|
"ethif",
|
|
|
"vdec",
|
|
|
+ "hif_sel",
|
|
|
NULL,
|
|
|
};
|
|
|
|
|
@@ -652,6 +664,53 @@ static const struct scp_subdomain scp_subdomain_mt6797[] = {
|
|
|
{MT6797_POWER_DOMAIN_MM, MT6797_POWER_DOMAIN_MJC},
|
|
|
};
|
|
|
|
|
|
+/*
|
|
|
+ * MT7622 power domain support
|
|
|
+ */
|
|
|
+
|
|
|
+static const struct scp_domain_data scp_domain_data_mt7622[] = {
|
|
|
+ [MT7622_POWER_DOMAIN_ETHSYS] = {
|
|
|
+ .name = "ethsys",
|
|
|
+ .sta_mask = PWR_STATUS_ETHSYS,
|
|
|
+ .ctl_offs = SPM_ETHSYS_PWR_CON,
|
|
|
+ .sram_pdn_bits = GENMASK(11, 8),
|
|
|
+ .sram_pdn_ack_bits = GENMASK(15, 12),
|
|
|
+ .clk_id = {CLK_NONE},
|
|
|
+ .bus_prot_mask = MT7622_TOP_AXI_PROT_EN_ETHSYS,
|
|
|
+ .active_wakeup = true,
|
|
|
+ },
|
|
|
+ [MT7622_POWER_DOMAIN_HIF0] = {
|
|
|
+ .name = "hif0",
|
|
|
+ .sta_mask = PWR_STATUS_HIF0,
|
|
|
+ .ctl_offs = SPM_HIF0_PWR_CON,
|
|
|
+ .sram_pdn_bits = GENMASK(11, 8),
|
|
|
+ .sram_pdn_ack_bits = GENMASK(15, 12),
|
|
|
+ .clk_id = {CLK_HIFSEL},
|
|
|
+ .bus_prot_mask = MT7622_TOP_AXI_PROT_EN_HIF0,
|
|
|
+ .active_wakeup = true,
|
|
|
+ },
|
|
|
+ [MT7622_POWER_DOMAIN_HIF1] = {
|
|
|
+ .name = "hif1",
|
|
|
+ .sta_mask = PWR_STATUS_HIF1,
|
|
|
+ .ctl_offs = SPM_HIF1_PWR_CON,
|
|
|
+ .sram_pdn_bits = GENMASK(11, 8),
|
|
|
+ .sram_pdn_ack_bits = GENMASK(15, 12),
|
|
|
+ .clk_id = {CLK_HIFSEL},
|
|
|
+ .bus_prot_mask = MT7622_TOP_AXI_PROT_EN_HIF1,
|
|
|
+ .active_wakeup = true,
|
|
|
+ },
|
|
|
+ [MT7622_POWER_DOMAIN_WB] = {
|
|
|
+ .name = "wb",
|
|
|
+ .sta_mask = PWR_STATUS_WB,
|
|
|
+ .ctl_offs = SPM_WB_PWR_CON,
|
|
|
+ .sram_pdn_bits = 0,
|
|
|
+ .sram_pdn_ack_bits = 0,
|
|
|
+ .clk_id = {CLK_NONE},
|
|
|
+ .bus_prot_mask = MT7622_TOP_AXI_PROT_EN_WB,
|
|
|
+ .active_wakeup = true,
|
|
|
+ },
|
|
|
+};
|
|
|
+
|
|
|
/*
|
|
|
* MT8173 power domain support
|
|
|
*/
|
|
@@ -771,6 +830,15 @@ static const struct scp_soc_data mt6797_data = {
|
|
|
}
|
|
|
};
|
|
|
|
|
|
+static const struct scp_soc_data mt7622_data = {
|
|
|
+ .domains = scp_domain_data_mt7622,
|
|
|
+ .num_domains = ARRAY_SIZE(scp_domain_data_mt7622),
|
|
|
+ .regs = {
|
|
|
+ .pwr_sta_offs = SPM_PWR_STATUS,
|
|
|
+ .pwr_sta2nd_offs = SPM_PWR_STATUS_2ND
|
|
|
+ }
|
|
|
+};
|
|
|
+
|
|
|
static const struct scp_soc_data mt8173_data = {
|
|
|
.domains = scp_domain_data_mt8173,
|
|
|
.num_domains = ARRAY_SIZE(scp_domain_data_mt8173),
|
|
@@ -793,6 +861,9 @@ static const struct of_device_id of_scpsys_match_tbl[] = {
|
|
|
}, {
|
|
|
.compatible = "mediatek,mt6797-scpsys",
|
|
|
.data = &mt6797_data,
|
|
|
+ }, {
|
|
|
+ .compatible = "mediatek,mt7622-scpsys",
|
|
|
+ .data = &mt7622_data,
|
|
|
}, {
|
|
|
.compatible = "mediatek,mt8173-scpsys",
|
|
|
.data = &mt8173_data,
|