Re: [PATCH 4/6] clk: rockchip: rk3399: update necessary critical clocks
From: Heiko Stübner
Date: Mon Apr 25 2016 - 18:04:36 EST
Am Mittwoch, 20. April 2016, 19:06:52 schrieb Xing Zheng:
> We need to declare that we enable all NOCs which are critical
> clocks always and clearly and explicitly show that we have enabled
> them at clk_summary.
>
> We need to add some has been verified and required critical clocks
> in the development process.
>
> And the pclk_perilp1_noc is also add CLK_IGNORE_UNUSED flag.
>
> Signed-off-by: Xing Zheng <zhengxing@xxxxxxxxxxxxxx>
> ---
>
> drivers/clk/rockchip/clk-rk3399.c | 72
> +++++++++++++++++++++++++++++++------ 1 file changed, 62 insertions(+), 10
> deletions(-)
>
> diff --git a/drivers/clk/rockchip/clk-rk3399.c
> b/drivers/clk/rockchip/clk-rk3399.c index 232ea68..1da4fe1 100644
> --- a/drivers/clk/rockchip/clk-rk3399.c
> +++ b/drivers/clk/rockchip/clk-rk3399.c
> @@ -1043,7 +1043,7 @@ static struct rockchip_clk_branch
> rk3399_clk_branches[] __initdata = { GATE(PCLK_SPI2, "pclk_spi2",
> "pclk_perilp1", 0, RK3399_CLKGATE_CON(23), 12, GFLAGS), GATE(PCLK_SPI4,
> "pclk_spi4", "pclk_perilp1", 0, RK3399_CLKGATE_CON(23), 13, GFLAGS),
> GATE(PCLK_PERIHP_GRF, "pclk_perilp_sgrf", "pclk_perilp1", 0,
> RK3399_CLKGATE_CON(24), 13, GFLAGS),
> - GATE(0, "pclk_perilp1_noc",
> "pclk_perilp1", 0, RK3399_CLKGATE_CON(25), 10, GFLAGS),
> + GATE(0,
> "pclk_perilp1_noc", "pclk_perilp1", CLK_IGNORE_UNUSED,
> RK3399_CLKGATE_CON(25), 10, GFLAGS),
why do you think you need a CLK_IGNORE_UNUSED when you have pclk_perilp1_noc
in the list of critical clocks below already? Aka as critical clock, it will
stay enabled anyway.
>
> /* saradc */
> COMPOSITE_NOMUX(SCLK_SARADC, "clk_saradc", "xin24m", 0,
> @@ -1464,33 +1464,85 @@ static struct rockchip_clk_branch
> rk3399_clk_pmu_branches[] __initdata = { };
>
> static const char *const rk3399_cru_critical_clocks[] __initconst = {
> - "aclk_cci_pre",
> + /*
> + * We need to declare that we enable all NOCs which are critical clocks
> + * always and clearly and explicitly show that we have enabled them at
> + * clk_summary.
> + */
I think that comment is not really helping here to explain the background.
Also, one thing I'd really like to know is what a NOC actually is. I know it's
related to the interconnect, but so far I haven't found anything explaining
the acronym.
Heiko
> + "aclk_usb3_noc",
> + "aclk_gmac_noc",
> + "pclk_gmac_noc",
> + "pclk_center_main_noc",
> + "aclk_cci_noc0",
> + "aclk_cci_noc1",
> + "clk_dbg_noc",
> + "hclk_vcodec_noc",
> + "aclk_vcodec_noc",
> + "hclk_vdu_noc",
> + "aclk_vdu_noc",
> + "hclk_iep_noc",
> + "aclk_iep_noc",
> + "hclk_rga_noc",
> + "aclk_rga_noc",
> + "aclk_center_main_noc",
> + "aclk_center_peri_noc",
> + "aclk_perihp_noc",
> + "hclk_perihp_noc",
> + "pclk_perihp_noc",
> + "hclk_sdmmc_noc",
> + "aclk_emmc_noc",
> + "aclk_perilp0_noc",
> + "hclk_perilp0_noc",
> + "hclk_m0_perilp_noc",
> + "hclk_perilp1_noc",
> + "hclk_sdio_noc",
> + "hclk_sdioaudio_noc",
> + "pclk_perilp1_noc",
> + "aclk_vio_noc",
> + "aclk_hdcp_noc",
> + "hclk_hdcp_noc",
> + "pclk_hdcp_noc",
> + "pclk_edp_noc",
> + "aclk_vop0_noc",
> + "hclk_vop0_noc",
> + "aclk_vop1_noc",
> + "hclk_vop1_noc",
> + "aclk_isp0_noc",
> + "hclk_isp0_noc",
> + "aclk_isp1_noc",
> + "hclk_isp1_noc",
> + "aclk_gic_noc",
> +
> + /* other critical clocks */
> "pclk_perilp0",
> "pclk_perilp0",
> "hclk_perilp0",
> - "hclk_perilp0_noc",
> "pclk_perilp1",
> - "pclk_perilp1_noc",
> "pclk_perihp",
> - "pclk_perihp_noc",
> "hclk_perihp",
> "aclk_perihp",
> - "aclk_perihp_noc",
> "aclk_perilp0",
> - "aclk_perilp0_noc",
> "hclk_perilp1",
> - "hclk_perilp1_noc",
> - "aclk_dmac0_perilp",
> - "gpll_hclk_perilp1_src",
> + "aclk_dmac1_perilp",
> "gpll_aclk_perilp0_src",
> "gpll_aclk_perihp_src",
> };
>
> static const char *const rk3399_pmucru_critical_clocks[] __initconst = {
> + /*
> + * We need to declare that we enable all NOCs which are critical clocks
> + * always and clearly and explicitly show that we have enabled them at
> + * clk_summary.
> + */
> + "pclk_noc_pmu",
> + "hclk_noc_pmu",
> +
> + /* other critical clocks */
> "ppll",
> "pclk_pmu_src",
> "fclk_cm0s_src_pmu",
> "clk_timer_src_pmu",
> + "pclk_rkpwm_pmu",
> };
>
> static void __init rk3399_clk_init(struct device_node *np)