Re: [PATCH v2 2/2] clk: qcom: Add qspi (Quad SPI) clocks for sdm845
Hi, On Mon, Jul 23, 2018 at 7:22 PM, Taniya Das wrote: > > > On 7/24/2018 3:24 AM, Douglas Anderson wrote: >> >> Add both the interface and core clock. >> >> Signed-off-by: Douglas Anderson >> --- >> >> Changes in v2: >> - Only 19.2, 100, 150, and 300 MHz now. >> - All clocks come from MAIN rather than EVEN. >> - Use parent map 0 instead of new parent map 9. >> >> drivers/clk/qcom/gcc-sdm845.c | 63 +++ >> 1 file changed, 63 insertions(+) >> >> diff --git a/drivers/clk/qcom/gcc-sdm845.c b/drivers/clk/qcom/gcc-sdm845.c >> index 0f694ed4238a..5bca634e277a 100644 >> --- a/drivers/clk/qcom/gcc-sdm845.c >> +++ b/drivers/clk/qcom/gcc-sdm845.c >> @@ -162,6 +162,13 @@ static const char * const gcc_parent_names_10[] = { >> "core_bi_pll_test_se", >> }; >> +static const char * const gcc_parent_names_9[] = { >> + "bi_tcxo", >> + "gpll0", >> + "gpll0_out_even", >> + "core_pi_sleep_clk", >> +}; >> + > > > Please remove this. Oops, that's embarrassing. Please stay tuned for v3. -Doug
Re: [PATCH v2 2/2] clk: qcom: Add qspi (Quad SPI) clocks for sdm845
Hi, On Mon, Jul 23, 2018 at 7:22 PM, Taniya Das wrote: > > > On 7/24/2018 3:24 AM, Douglas Anderson wrote: >> >> Add both the interface and core clock. >> >> Signed-off-by: Douglas Anderson >> --- >> >> Changes in v2: >> - Only 19.2, 100, 150, and 300 MHz now. >> - All clocks come from MAIN rather than EVEN. >> - Use parent map 0 instead of new parent map 9. >> >> drivers/clk/qcom/gcc-sdm845.c | 63 +++ >> 1 file changed, 63 insertions(+) >> >> diff --git a/drivers/clk/qcom/gcc-sdm845.c b/drivers/clk/qcom/gcc-sdm845.c >> index 0f694ed4238a..5bca634e277a 100644 >> --- a/drivers/clk/qcom/gcc-sdm845.c >> +++ b/drivers/clk/qcom/gcc-sdm845.c >> @@ -162,6 +162,13 @@ static const char * const gcc_parent_names_10[] = { >> "core_bi_pll_test_se", >> }; >> +static const char * const gcc_parent_names_9[] = { >> + "bi_tcxo", >> + "gpll0", >> + "gpll0_out_even", >> + "core_pi_sleep_clk", >> +}; >> + > > > Please remove this. Oops, that's embarrassing. Please stay tuned for v3. -Doug
Re: [PATCH v2 2/2] clk: qcom: Add qspi (Quad SPI) clocks for sdm845
On 7/24/2018 3:24 AM, Douglas Anderson wrote: Add both the interface and core clock. Signed-off-by: Douglas Anderson --- Changes in v2: - Only 19.2, 100, 150, and 300 MHz now. - All clocks come from MAIN rather than EVEN. - Use parent map 0 instead of new parent map 9. drivers/clk/qcom/gcc-sdm845.c | 63 +++ 1 file changed, 63 insertions(+) diff --git a/drivers/clk/qcom/gcc-sdm845.c b/drivers/clk/qcom/gcc-sdm845.c index 0f694ed4238a..5bca634e277a 100644 --- a/drivers/clk/qcom/gcc-sdm845.c +++ b/drivers/clk/qcom/gcc-sdm845.c @@ -162,6 +162,13 @@ static const char * const gcc_parent_names_10[] = { "core_bi_pll_test_se", }; +static const char * const gcc_parent_names_9[] = { + "bi_tcxo", + "gpll0", + "gpll0_out_even", + "core_pi_sleep_clk", +}; + Please remove this. static struct clk_alpha_pll gpll0 = { .offset = 0x0, .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA], @@ -358,6 +365,28 @@ static struct clk_rcg2 gcc_pcie_phy_refgen_clk_src = { }, }; +static const struct freq_tbl ftbl_gcc_qspi_core_clk_src[] = { + F(1920, P_BI_TCXO, 1, 0, 0), + F(1, P_GPLL0_OUT_MAIN, 6, 0, 0), + F(15000, P_GPLL0_OUT_MAIN, 4, 0, 0), + F(3, P_GPLL0_OUT_MAIN, 2, 0, 0), + { } +}; + +static struct clk_rcg2 gcc_qspi_core_clk_src = { + .cmd_rcgr = 0x4b008, + .mnd_width = 0, + .hid_width = 5, + .parent_map = gcc_parent_map_0, + .freq_tbl = ftbl_gcc_qspi_core_clk_src, + .clkr.hw.init = &(struct clk_init_data){ + .name = "gcc_qspi_core_clk_src", + .parent_names = gcc_parent_names_9, This would point to "gcc_parent_names_0". + .num_parents = 4, + .ops = _rcg2_floor_ops, + }, +}; + static const struct freq_tbl ftbl_gcc_pdm2_clk_src[] = { F(960, P_BI_TCXO, 2, 0, 0), F(1920, P_BI_TCXO, 1, 0, 0), @@ -1935,6 +1964,37 @@ static struct clk_branch gcc_qmip_video_ahb_clk = { }, }; +static struct clk_branch gcc_qspi_cnoc_periph_ahb_clk = { + .halt_reg = 0x4b000, + .halt_check = BRANCH_HALT, + .clkr = { + .enable_reg = 0x4b000, + .enable_mask = BIT(0), + .hw.init = &(struct clk_init_data){ + .name = "gcc_qspi_cnoc_periph_ahb_clk", + .ops = _branch2_ops, + }, + }, +}; + +static struct clk_branch gcc_qspi_core_clk = { + .halt_reg = 0x4b004, + .halt_check = BRANCH_HALT, + .clkr = { + .enable_reg = 0x4b004, + .enable_mask = BIT(0), + .hw.init = &(struct clk_init_data){ + .name = "gcc_qspi_core_clk", + .parent_names = (const char *[]){ + "gcc_qspi_core_clk_src", + }, + .num_parents = 1, + .flags = CLK_SET_RATE_PARENT, + .ops = _branch2_ops, + }, + }, +}; + static struct clk_branch gcc_qupv3_wrap0_s0_clk = { .halt_reg = 0x17030, .halt_check = BRANCH_HALT_VOTED, @@ -3383,6 +3443,9 @@ static struct clk_regmap *gcc_sdm845_clocks[] = { [GPLL4] = , [GCC_CPUSS_DVM_BUS_CLK] = _cpuss_dvm_bus_clk.clkr, [GCC_CPUSS_GNOC_CLK] = _cpuss_gnoc_clk.clkr, + [GCC_QSPI_CORE_CLK_SRC] = _qspi_core_clk_src.clkr, + [GCC_QSPI_CORE_CLK] = _qspi_core_clk.clkr, + [GCC_QSPI_CNOC_PERIPH_AHB_CLK] = _qspi_cnoc_periph_ahb_clk.clkr, }; static const struct qcom_reset_map gcc_sdm845_resets[] = { -- QUALCOMM INDIA, on behalf of Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, hosted by The Linux Foundation. --
Re: [PATCH v2 2/2] clk: qcom: Add qspi (Quad SPI) clocks for sdm845
On 7/24/2018 3:24 AM, Douglas Anderson wrote: Add both the interface and core clock. Signed-off-by: Douglas Anderson --- Changes in v2: - Only 19.2, 100, 150, and 300 MHz now. - All clocks come from MAIN rather than EVEN. - Use parent map 0 instead of new parent map 9. drivers/clk/qcom/gcc-sdm845.c | 63 +++ 1 file changed, 63 insertions(+) diff --git a/drivers/clk/qcom/gcc-sdm845.c b/drivers/clk/qcom/gcc-sdm845.c index 0f694ed4238a..5bca634e277a 100644 --- a/drivers/clk/qcom/gcc-sdm845.c +++ b/drivers/clk/qcom/gcc-sdm845.c @@ -162,6 +162,13 @@ static const char * const gcc_parent_names_10[] = { "core_bi_pll_test_se", }; +static const char * const gcc_parent_names_9[] = { + "bi_tcxo", + "gpll0", + "gpll0_out_even", + "core_pi_sleep_clk", +}; + Please remove this. static struct clk_alpha_pll gpll0 = { .offset = 0x0, .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA], @@ -358,6 +365,28 @@ static struct clk_rcg2 gcc_pcie_phy_refgen_clk_src = { }, }; +static const struct freq_tbl ftbl_gcc_qspi_core_clk_src[] = { + F(1920, P_BI_TCXO, 1, 0, 0), + F(1, P_GPLL0_OUT_MAIN, 6, 0, 0), + F(15000, P_GPLL0_OUT_MAIN, 4, 0, 0), + F(3, P_GPLL0_OUT_MAIN, 2, 0, 0), + { } +}; + +static struct clk_rcg2 gcc_qspi_core_clk_src = { + .cmd_rcgr = 0x4b008, + .mnd_width = 0, + .hid_width = 5, + .parent_map = gcc_parent_map_0, + .freq_tbl = ftbl_gcc_qspi_core_clk_src, + .clkr.hw.init = &(struct clk_init_data){ + .name = "gcc_qspi_core_clk_src", + .parent_names = gcc_parent_names_9, This would point to "gcc_parent_names_0". + .num_parents = 4, + .ops = _rcg2_floor_ops, + }, +}; + static const struct freq_tbl ftbl_gcc_pdm2_clk_src[] = { F(960, P_BI_TCXO, 2, 0, 0), F(1920, P_BI_TCXO, 1, 0, 0), @@ -1935,6 +1964,37 @@ static struct clk_branch gcc_qmip_video_ahb_clk = { }, }; +static struct clk_branch gcc_qspi_cnoc_periph_ahb_clk = { + .halt_reg = 0x4b000, + .halt_check = BRANCH_HALT, + .clkr = { + .enable_reg = 0x4b000, + .enable_mask = BIT(0), + .hw.init = &(struct clk_init_data){ + .name = "gcc_qspi_cnoc_periph_ahb_clk", + .ops = _branch2_ops, + }, + }, +}; + +static struct clk_branch gcc_qspi_core_clk = { + .halt_reg = 0x4b004, + .halt_check = BRANCH_HALT, + .clkr = { + .enable_reg = 0x4b004, + .enable_mask = BIT(0), + .hw.init = &(struct clk_init_data){ + .name = "gcc_qspi_core_clk", + .parent_names = (const char *[]){ + "gcc_qspi_core_clk_src", + }, + .num_parents = 1, + .flags = CLK_SET_RATE_PARENT, + .ops = _branch2_ops, + }, + }, +}; + static struct clk_branch gcc_qupv3_wrap0_s0_clk = { .halt_reg = 0x17030, .halt_check = BRANCH_HALT_VOTED, @@ -3383,6 +3443,9 @@ static struct clk_regmap *gcc_sdm845_clocks[] = { [GPLL4] = , [GCC_CPUSS_DVM_BUS_CLK] = _cpuss_dvm_bus_clk.clkr, [GCC_CPUSS_GNOC_CLK] = _cpuss_gnoc_clk.clkr, + [GCC_QSPI_CORE_CLK_SRC] = _qspi_core_clk_src.clkr, + [GCC_QSPI_CORE_CLK] = _qspi_core_clk.clkr, + [GCC_QSPI_CNOC_PERIPH_AHB_CLK] = _qspi_cnoc_periph_ahb_clk.clkr, }; static const struct qcom_reset_map gcc_sdm845_resets[] = { -- QUALCOMM INDIA, on behalf of Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, hosted by The Linux Foundation. --