Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

soc: mediatek: Add MT2701 scpsys driver

Add scpsys driver for MT2701.

mtk-scpsys now supports MT8173 (arm64) and MT2701 (arm). So it should
be enabled on both arm64 and arm platforms.

Signed-off-by: Shunli Wang <shunli.wang@mediatek.com>
Signed-off-by: James Liao <jamesjj.liao@mediatek.com>
Reviewed-by: Kevin Hilman <khilman@baylibre.com>
Signed-off-by: Matthias Brugger <matthias.bgg@gmail.com>

authored by

Shunli Wang and committed by
Matthias Brugger
112ef188 6078c651

+117 -2
+1 -1
drivers/soc/mediatek/Kconfig
··· 23 23 config MTK_SCPSYS 24 24 bool "MediaTek SCPSYS Support" 25 25 depends on ARCH_MEDIATEK || COMPILE_TEST 26 - default ARM64 && ARCH_MEDIATEK 26 + default ARCH_MEDIATEK 27 27 select REGMAP 28 28 select MTK_INFRACFG 29 29 select PM_GENERIC_DOMAINS if PM
+116 -1
drivers/soc/mediatek/mtk-scpsys.c
··· 20 20 #include <linux/regulator/consumer.h> 21 21 #include <linux/soc/mediatek/infracfg.h> 22 22 23 + #include <dt-bindings/power/mt2701-power.h> 23 24 #include <dt-bindings/power/mt8173-power.h> 24 25 25 26 #define SPM_VDE_PWR_CON 0x0210 ··· 28 27 #define SPM_VEN_PWR_CON 0x0230 29 28 #define SPM_ISP_PWR_CON 0x0238 30 29 #define SPM_DIS_PWR_CON 0x023c 30 + #define SPM_CONN_PWR_CON 0x0280 31 31 #define SPM_VEN2_PWR_CON 0x0298 32 - #define SPM_AUDIO_PWR_CON 0x029c 32 + #define SPM_AUDIO_PWR_CON 0x029c /* MT8173 */ 33 + #define SPM_BDP_PWR_CON 0x029c /* MT2701 */ 34 + #define SPM_ETH_PWR_CON 0x02a0 35 + #define SPM_HIF_PWR_CON 0x02a4 36 + #define SPM_IFR_MSC_PWR_CON 0x02a8 33 37 #define SPM_MFG_2D_PWR_CON 0x02c0 34 38 #define SPM_MFG_ASYNC_PWR_CON 0x02c4 35 39 #define SPM_USB_PWR_CON 0x02cc ··· 48 42 #define PWR_ON_2ND_BIT BIT(3) 49 43 #define PWR_CLK_DIS_BIT BIT(4) 50 44 45 + #define PWR_STATUS_CONN BIT(1) 51 46 #define PWR_STATUS_DISP BIT(3) 52 47 #define PWR_STATUS_MFG BIT(4) 53 48 #define PWR_STATUS_ISP BIT(5) 54 49 #define PWR_STATUS_VDEC BIT(7) 50 + #define PWR_STATUS_BDP BIT(14) 51 + #define PWR_STATUS_ETH BIT(15) 52 + #define PWR_STATUS_HIF BIT(16) 53 + #define PWR_STATUS_IFR_MSC BIT(17) 55 54 #define PWR_STATUS_VENC_LT BIT(20) 56 55 #define PWR_STATUS_VENC BIT(21) 57 56 #define PWR_STATUS_MFG_2D BIT(22) ··· 70 59 CLK_MFG, 71 60 CLK_VENC, 72 61 CLK_VENC_LT, 62 + CLK_ETHIF, 73 63 CLK_MAX, 74 64 }; 75 65 ··· 80 68 "mfg", 81 69 "venc", 82 70 "venc_lt", 71 + "ethif", 83 72 NULL, 84 73 }; 85 74 ··· 468 455 } 469 456 470 457 /* 458 + * MT2701 power domain support 459 + */ 460 + 461 + static const struct scp_domain_data scp_domain_data_mt2701[] = { 462 + [MT2701_POWER_DOMAIN_CONN] = { 463 + .name = "conn", 464 + .sta_mask = PWR_STATUS_CONN, 465 + .ctl_offs = SPM_CONN_PWR_CON, 466 + .bus_prot_mask = 0x0104, 467 + .clk_id = {CLK_NONE}, 468 + .active_wakeup = true, 469 + }, 470 + [MT2701_POWER_DOMAIN_DISP] = { 471 + .name = "disp", 472 + .sta_mask = PWR_STATUS_DISP, 473 + .ctl_offs = SPM_DIS_PWR_CON, 474 + .sram_pdn_bits = GENMASK(11, 8), 475 + .clk_id = {CLK_MM}, 476 + .bus_prot_mask = 0x0002, 477 + .active_wakeup = true, 478 + }, 479 + [MT2701_POWER_DOMAIN_MFG] = { 480 + .name = "mfg", 481 + .sta_mask = PWR_STATUS_MFG, 482 + .ctl_offs = SPM_MFG_PWR_CON, 483 + .sram_pdn_bits = GENMASK(11, 8), 484 + .sram_pdn_ack_bits = GENMASK(12, 12), 485 + .clk_id = {CLK_MFG}, 486 + .active_wakeup = true, 487 + }, 488 + [MT2701_POWER_DOMAIN_VDEC] = { 489 + .name = "vdec", 490 + .sta_mask = PWR_STATUS_VDEC, 491 + .ctl_offs = SPM_VDE_PWR_CON, 492 + .sram_pdn_bits = GENMASK(11, 8), 493 + .sram_pdn_ack_bits = GENMASK(12, 12), 494 + .clk_id = {CLK_MM}, 495 + .active_wakeup = true, 496 + }, 497 + [MT2701_POWER_DOMAIN_ISP] = { 498 + .name = "isp", 499 + .sta_mask = PWR_STATUS_ISP, 500 + .ctl_offs = SPM_ISP_PWR_CON, 501 + .sram_pdn_bits = GENMASK(11, 8), 502 + .sram_pdn_ack_bits = GENMASK(13, 12), 503 + .clk_id = {CLK_MM}, 504 + .active_wakeup = true, 505 + }, 506 + [MT2701_POWER_DOMAIN_BDP] = { 507 + .name = "bdp", 508 + .sta_mask = PWR_STATUS_BDP, 509 + .ctl_offs = SPM_BDP_PWR_CON, 510 + .sram_pdn_bits = GENMASK(11, 8), 511 + .clk_id = {CLK_NONE}, 512 + .active_wakeup = true, 513 + }, 514 + [MT2701_POWER_DOMAIN_ETH] = { 515 + .name = "eth", 516 + .sta_mask = PWR_STATUS_ETH, 517 + .ctl_offs = SPM_ETH_PWR_CON, 518 + .sram_pdn_bits = GENMASK(11, 8), 519 + .sram_pdn_ack_bits = GENMASK(15, 12), 520 + .clk_id = {CLK_ETHIF}, 521 + .active_wakeup = true, 522 + }, 523 + [MT2701_POWER_DOMAIN_HIF] = { 524 + .name = "hif", 525 + .sta_mask = PWR_STATUS_HIF, 526 + .ctl_offs = SPM_HIF_PWR_CON, 527 + .sram_pdn_bits = GENMASK(11, 8), 528 + .sram_pdn_ack_bits = GENMASK(15, 12), 529 + .clk_id = {CLK_ETHIF}, 530 + .active_wakeup = true, 531 + }, 532 + [MT2701_POWER_DOMAIN_IFR_MSC] = { 533 + .name = "ifr_msc", 534 + .sta_mask = PWR_STATUS_IFR_MSC, 535 + .ctl_offs = SPM_IFR_MSC_PWR_CON, 536 + .clk_id = {CLK_NONE}, 537 + .active_wakeup = true, 538 + }, 539 + }; 540 + 541 + #define NUM_DOMAINS_MT2701 ARRAY_SIZE(scp_domain_data_mt2701) 542 + 543 + static int __init scpsys_probe_mt2701(struct platform_device *pdev) 544 + { 545 + struct scp *scp; 546 + 547 + scp = init_scp(pdev, scp_domain_data_mt2701, NUM_DOMAINS_MT2701); 548 + if (IS_ERR(scp)) 549 + return PTR_ERR(scp); 550 + 551 + mtk_register_power_domains(pdev, scp, NUM_DOMAINS_MT2701); 552 + 553 + return 0; 554 + } 555 + 556 + /* 471 557 * MT8173 power domain support 472 558 */ 473 559 ··· 695 583 696 584 static const struct of_device_id of_scpsys_match_tbl[] = { 697 585 { 586 + .compatible = "mediatek,mt2701-scpsys", 587 + .data = scpsys_probe_mt2701, 588 + }, { 698 589 .compatible = "mediatek,mt8173-scpsys", 699 590 .data = scpsys_probe_mt8173, 700 591 }, {