|
@@ -21,6 +21,7 @@
|
|
|
#include <linux/soc/mediatek/infracfg.h>
|
|
|
|
|
|
#include <dt-bindings/power/mt2701-power.h>
|
|
|
+#include <dt-bindings/power/mt6797-power.h>
|
|
|
#include <dt-bindings/power/mt8173-power.h>
|
|
|
|
|
|
#define SPM_VDE_PWR_CON 0x0210
|
|
@@ -584,6 +585,116 @@ static int __init scpsys_probe_mt2701(struct platform_device *pdev)
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
+/*
|
|
|
+ * MT6797 power domain support
|
|
|
+ */
|
|
|
+
|
|
|
+static const struct scp_domain_data scp_domain_data_mt6797[] = {
|
|
|
+ [MT6797_POWER_DOMAIN_VDEC] = {
|
|
|
+ .name = "vdec",
|
|
|
+ .sta_mask = BIT(7),
|
|
|
+ .ctl_offs = 0x300,
|
|
|
+ .sram_pdn_bits = GENMASK(8, 8),
|
|
|
+ .sram_pdn_ack_bits = GENMASK(12, 12),
|
|
|
+ .clk_id = {CLK_VDEC},
|
|
|
+ },
|
|
|
+ [MT6797_POWER_DOMAIN_VENC] = {
|
|
|
+ .name = "venc",
|
|
|
+ .sta_mask = BIT(21),
|
|
|
+ .ctl_offs = 0x304,
|
|
|
+ .sram_pdn_bits = GENMASK(11, 8),
|
|
|
+ .sram_pdn_ack_bits = GENMASK(15, 12),
|
|
|
+ .clk_id = {CLK_NONE},
|
|
|
+ },
|
|
|
+ [MT6797_POWER_DOMAIN_ISP] = {
|
|
|
+ .name = "isp",
|
|
|
+ .sta_mask = BIT(5),
|
|
|
+ .ctl_offs = 0x308,
|
|
|
+ .sram_pdn_bits = GENMASK(9, 8),
|
|
|
+ .sram_pdn_ack_bits = GENMASK(13, 12),
|
|
|
+ .clk_id = {CLK_NONE},
|
|
|
+ },
|
|
|
+ [MT6797_POWER_DOMAIN_MM] = {
|
|
|
+ .name = "mm",
|
|
|
+ .sta_mask = BIT(3),
|
|
|
+ .ctl_offs = 0x30C,
|
|
|
+ .sram_pdn_bits = GENMASK(8, 8),
|
|
|
+ .sram_pdn_ack_bits = GENMASK(12, 12),
|
|
|
+ .clk_id = {CLK_MM},
|
|
|
+ .bus_prot_mask = (BIT(1) | BIT(2)),
|
|
|
+ },
|
|
|
+ [MT6797_POWER_DOMAIN_AUDIO] = {
|
|
|
+ .name = "audio",
|
|
|
+ .sta_mask = BIT(24),
|
|
|
+ .ctl_offs = 0x314,
|
|
|
+ .sram_pdn_bits = GENMASK(11, 8),
|
|
|
+ .sram_pdn_ack_bits = GENMASK(15, 12),
|
|
|
+ .clk_id = {CLK_NONE},
|
|
|
+ },
|
|
|
+ [MT6797_POWER_DOMAIN_MFG_ASYNC] = {
|
|
|
+ .name = "mfg_async",
|
|
|
+ .sta_mask = BIT(13),
|
|
|
+ .ctl_offs = 0x334,
|
|
|
+ .sram_pdn_bits = 0,
|
|
|
+ .sram_pdn_ack_bits = 0,
|
|
|
+ .clk_id = {CLK_MFG},
|
|
|
+ },
|
|
|
+ [MT6797_POWER_DOMAIN_MJC] = {
|
|
|
+ .name = "mjc",
|
|
|
+ .sta_mask = BIT(20),
|
|
|
+ .ctl_offs = 0x310,
|
|
|
+ .sram_pdn_bits = GENMASK(8, 8),
|
|
|
+ .sram_pdn_ack_bits = GENMASK(12, 12),
|
|
|
+ .clk_id = {CLK_NONE},
|
|
|
+ },
|
|
|
+};
|
|
|
+
|
|
|
+#define NUM_DOMAINS_MT6797 ARRAY_SIZE(scp_domain_data_mt6797)
|
|
|
+#define SPM_PWR_STATUS_MT6797 0x0180
|
|
|
+#define SPM_PWR_STATUS_2ND_MT6797 0x0184
|
|
|
+
|
|
|
+static int __init scpsys_probe_mt6797(struct platform_device *pdev)
|
|
|
+{
|
|
|
+ struct scp *scp;
|
|
|
+ struct genpd_onecell_data *pd_data;
|
|
|
+ int ret;
|
|
|
+ struct scp_ctrl_reg scp_reg;
|
|
|
+
|
|
|
+ scp_reg.pwr_sta_offs = SPM_PWR_STATUS_MT6797;
|
|
|
+ scp_reg.pwr_sta2nd_offs = SPM_PWR_STATUS_2ND_MT6797;
|
|
|
+
|
|
|
+ scp = init_scp(pdev, scp_domain_data_mt6797, NUM_DOMAINS_MT6797,
|
|
|
+ &scp_reg);
|
|
|
+ if (IS_ERR(scp))
|
|
|
+ return PTR_ERR(scp);
|
|
|
+
|
|
|
+ mtk_register_power_domains(pdev, scp, NUM_DOMAINS_MT6797);
|
|
|
+
|
|
|
+ pd_data = &scp->pd_data;
|
|
|
+
|
|
|
+ ret = pm_genpd_add_subdomain(pd_data->domains[MT6797_POWER_DOMAIN_MM],
|
|
|
+ pd_data->domains[MT6797_POWER_DOMAIN_VDEC]);
|
|
|
+ if (ret && IS_ENABLED(CONFIG_PM))
|
|
|
+ dev_err(&pdev->dev, "Failed to add subdomain: %d\n", ret);
|
|
|
+
|
|
|
+ ret = pm_genpd_add_subdomain(pd_data->domains[MT6797_POWER_DOMAIN_MM],
|
|
|
+ pd_data->domains[MT6797_POWER_DOMAIN_ISP]);
|
|
|
+ if (ret && IS_ENABLED(CONFIG_PM))
|
|
|
+ dev_err(&pdev->dev, "Failed to add subdomain: %d\n", ret);
|
|
|
+
|
|
|
+ ret = pm_genpd_add_subdomain(pd_data->domains[MT6797_POWER_DOMAIN_MM],
|
|
|
+ pd_data->domains[MT6797_POWER_DOMAIN_VENC]);
|
|
|
+ if (ret && IS_ENABLED(CONFIG_PM))
|
|
|
+ dev_err(&pdev->dev, "Failed to add subdomain: %d\n", ret);
|
|
|
+
|
|
|
+ ret = pm_genpd_add_subdomain(pd_data->domains[MT6797_POWER_DOMAIN_MM],
|
|
|
+ pd_data->domains[MT6797_POWER_DOMAIN_MJC]);
|
|
|
+ if (ret && IS_ENABLED(CONFIG_PM))
|
|
|
+ dev_err(&pdev->dev, "Failed to add subdomain: %d\n", ret);
|
|
|
+
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
/*
|
|
|
* MT8173 power domain support
|
|
|
*/
|
|
@@ -720,6 +831,9 @@ static const struct of_device_id of_scpsys_match_tbl[] = {
|
|
|
{
|
|
|
.compatible = "mediatek,mt2701-scpsys",
|
|
|
.data = scpsys_probe_mt2701,
|
|
|
+ }, {
|
|
|
+ .compatible = "mediatek,mt6797-scpsys",
|
|
|
+ .data = scpsys_probe_mt6797,
|
|
|
}, {
|
|
|
.compatible = "mediatek,mt8173-scpsys",
|
|
|
.data = scpsys_probe_mt8173,
|