]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
clk: qcom: smd: Add support for QCS404 rpm clocks
authorTaniya Das <tdas@codeaurora.org>
Sat, 3 Nov 2018 07:00:02 +0000 (00:00 -0700)
committerStephen Boyd <sboyd@kernel.org>
Tue, 6 Nov 2018 17:47:37 +0000 (09:47 -0800)
Add rpm smd clocks, PMIC and bus clocks which are required on QCS404
for clients to vote on.

Signed-off-by: Taniya Das <tdas@codeaurora.org>
Signed-off-by: Anu Ramanathan <anur@codeaurora.org>
[bjorn: Dropped cxo, voter clocks and static initialization]
Signed-off-by: Bjorn Andersson <bjorn.andersson@linaro.org>
Signed-off-by: Stephen Boyd <sboyd@kernel.org>
Documentation/devicetree/bindings/clock/qcom,rpmcc.txt
drivers/clk/qcom/clk-smd-rpm.c
include/dt-bindings/clock/qcom,rpmcc.h

index 4491d1c104aacd3b41e73856338c81afc9722f36..87b4949e9bc8e81c2cdaa5b8de040be571da006f 100644 (file)
@@ -16,6 +16,7 @@ Required properties :
                        "qcom,rpmcc-msm8974", "qcom,rpmcc"
                        "qcom,rpmcc-apq8064", "qcom,rpmcc"
                        "qcom,rpmcc-msm8996", "qcom,rpmcc"
+                       "qcom,rpmcc-qcs404", "qcom,rpmcc"
 
 - #clock-cells : shall contain 1
 
index 850c02a5224846530b0f601a97edae69ba569919..d3aadaeb2903348d7e31ed3c2e115badc200a4e3 100644 (file)
@@ -611,10 +611,55 @@ static const struct rpm_smd_clk_desc rpm_clk_msm8996 = {
        .num_clks = ARRAY_SIZE(msm8996_clks),
 };
 
+/* QCS404 */
+DEFINE_CLK_SMD_RPM_QDSS(qcs404, qdss_clk, qdss_a_clk, QCOM_SMD_RPM_MISC_CLK, 1);
+
+DEFINE_CLK_SMD_RPM(qcs404, pnoc_clk, pnoc_a_clk, QCOM_SMD_RPM_BUS_CLK, 0);
+DEFINE_CLK_SMD_RPM(qcs404, snoc_clk, snoc_a_clk, QCOM_SMD_RPM_BUS_CLK, 1);
+
+DEFINE_CLK_SMD_RPM(qcs404, bimc_clk, bimc_a_clk, QCOM_SMD_RPM_MEM_CLK, 0);
+DEFINE_CLK_SMD_RPM(qcs404, bimc_gpu_clk, bimc_gpu_a_clk, QCOM_SMD_RPM_MEM_CLK, 2);
+
+DEFINE_CLK_SMD_RPM(qcs404, qpic_clk, qpic_a_clk, QCOM_SMD_RPM_QPIC_CLK, 0);
+DEFINE_CLK_SMD_RPM(qcs404, ce1_clk, ce1_a_clk, QCOM_SMD_RPM_CE_CLK, 0);
+
+DEFINE_CLK_SMD_RPM_XO_BUFFER(qcs404, rf_clk1, rf_clk1_a, 4);
+DEFINE_CLK_SMD_RPM_XO_BUFFER_PINCTRL(qcs404, rf_clk1_pin, rf_clk1_a_pin, 4);
+
+DEFINE_CLK_SMD_RPM_XO_BUFFER(qcs404, ln_bb_clk, ln_bb_a_clk, 8);
+DEFINE_CLK_SMD_RPM_XO_BUFFER_PINCTRL(qcs404, ln_bb_clk_pin, ln_bb_clk_a_pin, 8);
+
+static struct clk_smd_rpm *qcs404_clks[] = {
+       [RPM_SMD_QDSS_CLK] = &qcs404_qdss_clk,
+       [RPM_SMD_QDSS_A_CLK] = &qcs404_qdss_a_clk,
+       [RPM_SMD_PNOC_CLK] = &qcs404_pnoc_clk,
+       [RPM_SMD_PNOC_A_CLK] = &qcs404_pnoc_a_clk,
+       [RPM_SMD_SNOC_CLK] = &qcs404_snoc_clk,
+       [RPM_SMD_SNOC_A_CLK] = &qcs404_snoc_a_clk,
+       [RPM_SMD_BIMC_CLK] = &qcs404_bimc_clk,
+       [RPM_SMD_BIMC_A_CLK] = &qcs404_bimc_a_clk,
+       [RPM_SMD_BIMC_GPU_CLK] = &qcs404_bimc_gpu_clk,
+       [RPM_SMD_BIMC_GPU_A_CLK] = &qcs404_bimc_gpu_a_clk,
+       [RPM_SMD_QPIC_CLK] = &qcs404_qpic_clk,
+       [RPM_SMD_QPIC_CLK_A] = &qcs404_qpic_a_clk,
+       [RPM_SMD_CE1_CLK] = &qcs404_ce1_clk,
+       [RPM_SMD_CE1_A_CLK] = &qcs404_ce1_a_clk,
+       [RPM_SMD_RF_CLK1] = &qcs404_rf_clk1,
+       [RPM_SMD_RF_CLK1_A] = &qcs404_rf_clk1_a,
+       [RPM_SMD_LN_BB_CLK] = &qcs404_ln_bb_clk,
+       [RPM_SMD_LN_BB_A_CLK] = &qcs404_ln_bb_a_clk,
+};
+
+static const struct rpm_smd_clk_desc rpm_clk_qcs404 = {
+       .clks = qcs404_clks,
+       .num_clks = ARRAY_SIZE(qcs404_clks),
+};
+
 static const struct of_device_id rpm_smd_clk_match_table[] = {
        { .compatible = "qcom,rpmcc-msm8916", .data = &rpm_clk_msm8916 },
        { .compatible = "qcom,rpmcc-msm8974", .data = &rpm_clk_msm8974 },
        { .compatible = "qcom,rpmcc-msm8996", .data = &rpm_clk_msm8996 },
+       { .compatible = "qcom,rpmcc-qcs404",  .data = &rpm_clk_qcs404  },
        { }
 };
 MODULE_DEVICE_TABLE(of, rpm_smd_clk_match_table);
index c585b82b9c056d489f8f383d8da9cf40bfb6948f..3658b0c14966767d01e5eadeac130e980f7fea7c 100644 (file)
 #define RPM_SMD_DIV_A_CLK3                     73
 #define RPM_SMD_LN_BB_CLK                      74
 #define RPM_SMD_LN_BB_A_CLK                    75
+#define RPM_SMD_BIMC_GPU_CLK                   76
+#define RPM_SMD_BIMC_GPU_A_CLK                 77
+#define RPM_SMD_QPIC_CLK                       78
+#define RPM_SMD_QPIC_CLK_A                     79
 
 #endif