arm64: dts: qcom: sm8550: Supply clock from cpufreq node to CPUs
authorManivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Wed, 15 Feb 2023 07:03:52 +0000 (12:33 +0530)
committerBjorn Andersson <andersson@kernel.org>
Wed, 15 Mar 2023 02:30:47 +0000 (19:30 -0700)
Qualcomm platforms making use of CPUFreq HW Engine (EPSS/OSM) supply clocks
to the CPU cores. But this relationship is not represented in DTS so far.

So let's make cpufreq node as the clock provider and CPU nodes as the
consumers. The clock index for each CPU node is based on the frequency
domain index.

Signed-off-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Reviewed-by: Konrad Dybcio <konrad.dybcio@linaro.org>
Signed-off-by: Bjorn Andersson <andersson@kernel.org>
Link: https://lore.kernel.org/r/20230215070400.5901-5-manivannan.sadhasivam@linaro.org
arch/arm64/boot/dts/qcom/sm8550.dtsi

index 8992d6580bf3ba6e64d6d9adfea09792a2bfde49..71051fb4172b51a40dd0648ec8f2cbd55aa7aa6d 100644 (file)
@@ -68,6 +68,7 @@
                        device_type = "cpu";
                        compatible = "qcom,kryo";
                        reg = <0 0>;
+                       clocks = <&cpufreq_hw 0>;
                        enable-method = "psci";
                        next-level-cache = <&L2_0>;
                        power-domains = <&CPU_PD0>;
@@ -91,6 +92,7 @@
                        device_type = "cpu";
                        compatible = "qcom,kryo";
                        reg = <0 0x100>;
+                       clocks = <&cpufreq_hw 0>;
                        enable-method = "psci";
                        next-level-cache = <&L2_100>;
                        power-domains = <&CPU_PD1>;
                        device_type = "cpu";
                        compatible = "qcom,kryo";
                        reg = <0 0x200>;
+                       clocks = <&cpufreq_hw 0>;
                        enable-method = "psci";
                        next-level-cache = <&L2_200>;
                        power-domains = <&CPU_PD2>;
                        device_type = "cpu";
                        compatible = "qcom,kryo";
                        reg = <0 0x300>;
+                       clocks = <&cpufreq_hw 1>;
                        enable-method = "psci";
                        next-level-cache = <&L2_300>;
                        power-domains = <&CPU_PD3>;
                        device_type = "cpu";
                        compatible = "qcom,kryo";
                        reg = <0 0x400>;
+                       clocks = <&cpufreq_hw 1>;
                        enable-method = "psci";
                        next-level-cache = <&L2_400>;
                        power-domains = <&CPU_PD4>;
                        device_type = "cpu";
                        compatible = "qcom,kryo";
                        reg = <0 0x500>;
+                       clocks = <&cpufreq_hw 1>;
                        enable-method = "psci";
                        next-level-cache = <&L2_500>;
                        power-domains = <&CPU_PD5>;
                        device_type = "cpu";
                        compatible = "qcom,kryo";
                        reg = <0 0x600>;
+                       clocks = <&cpufreq_hw 1>;
                        enable-method = "psci";
                        next-level-cache = <&L2_600>;
                        power-domains = <&CPU_PD6>;
                        device_type = "cpu";
                        compatible = "qcom,kryo";
                        reg = <0 0x700>;
+                       clocks = <&cpufreq_hw 2>;
                        enable-method = "psci";
                        next-level-cache = <&L2_700>;
                        power-domains = <&CPU_PD7>;
                                     <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
                        interrupt-names = "dcvsh-irq-0", "dcvsh-irq-1", "dcvsh-irq-2";
                        #freq-domain-cells = <1>;
+                       #clock-cells = <1>;
                };
 
                pmu@24091000 {