Commit 99860540 authored by Leo Yan's avatar Leo Yan Committed by Wei Xu

arm64: dts: add Hi6220's stub clock node

Enable SRAM node and stub clock node for Hi6220, which uses mailbox
channel 1 for CPU's frequency change.

Furthermore, add the CPU clock phandle in CPU's node and using
operating-points-v2 to register operating points. So can be used by
cpufreq-dt driver.
Signed-off-by: default avatarLeo Yan <leo.yan@linaro.org>
Acked-by: default avatarJassi Brar <jassisinghbrar@gmail.com>
Signed-off-by: default avatarWei Xu <xuwei5@hisilicon.com>
parent 86073570
...@@ -82,6 +82,11 @@ cpu0: cpu@0 { ...@@ -82,6 +82,11 @@ cpu0: cpu@0 {
device_type = "cpu"; device_type = "cpu";
reg = <0x0 0x0>; reg = <0x0 0x0>;
enable-method = "psci"; enable-method = "psci";
clocks = <&stub_clock 0>;
operating-points-v2 = <&cpu_opp_table>;
cooling-min-level = <4>;
cooling-max-level = <0>;
#cooling-cells = <2>; /* min followed by max */
cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>; cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>;
}; };
...@@ -90,6 +95,7 @@ cpu1: cpu@1 { ...@@ -90,6 +95,7 @@ cpu1: cpu@1 {
device_type = "cpu"; device_type = "cpu";
reg = <0x0 0x1>; reg = <0x0 0x1>;
enable-method = "psci"; enable-method = "psci";
operating-points-v2 = <&cpu_opp_table>;
cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>; cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>;
}; };
...@@ -98,6 +104,7 @@ cpu2: cpu@2 { ...@@ -98,6 +104,7 @@ cpu2: cpu@2 {
device_type = "cpu"; device_type = "cpu";
reg = <0x0 0x2>; reg = <0x0 0x2>;
enable-method = "psci"; enable-method = "psci";
operating-points-v2 = <&cpu_opp_table>;
cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>; cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>;
}; };
...@@ -106,6 +113,7 @@ cpu3: cpu@3 { ...@@ -106,6 +113,7 @@ cpu3: cpu@3 {
device_type = "cpu"; device_type = "cpu";
reg = <0x0 0x3>; reg = <0x0 0x3>;
enable-method = "psci"; enable-method = "psci";
operating-points-v2 = <&cpu_opp_table>;
cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>; cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>;
}; };
...@@ -114,6 +122,7 @@ cpu4: cpu@100 { ...@@ -114,6 +122,7 @@ cpu4: cpu@100 {
device_type = "cpu"; device_type = "cpu";
reg = <0x0 0x100>; reg = <0x0 0x100>;
enable-method = "psci"; enable-method = "psci";
operating-points-v2 = <&cpu_opp_table>;
cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>; cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>;
}; };
...@@ -122,6 +131,7 @@ cpu5: cpu@101 { ...@@ -122,6 +131,7 @@ cpu5: cpu@101 {
device_type = "cpu"; device_type = "cpu";
reg = <0x0 0x101>; reg = <0x0 0x101>;
enable-method = "psci"; enable-method = "psci";
operating-points-v2 = <&cpu_opp_table>;
cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>; cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>;
}; };
...@@ -130,6 +140,7 @@ cpu6: cpu@102 { ...@@ -130,6 +140,7 @@ cpu6: cpu@102 {
device_type = "cpu"; device_type = "cpu";
reg = <0x0 0x102>; reg = <0x0 0x102>;
enable-method = "psci"; enable-method = "psci";
operating-points-v2 = <&cpu_opp_table>;
cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>; cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>;
}; };
...@@ -138,10 +149,42 @@ cpu7: cpu@103 { ...@@ -138,10 +149,42 @@ cpu7: cpu@103 {
device_type = "cpu"; device_type = "cpu";
reg = <0x0 0x103>; reg = <0x0 0x103>;
enable-method = "psci"; enable-method = "psci";
operating-points-v2 = <&cpu_opp_table>;
cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>; cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>;
}; };
}; };
cpu_opp_table: cpu_opp_table {
compatible = "operating-points-v2";
opp-shared;
opp00 {
opp-hz = /bits/ 64 <208000000>;
opp-microvolt = <1040000>;
clock-latency-ns = <500000>;
};
opp01 {
opp-hz = /bits/ 64 <432000000>;
opp-microvolt = <1040000>;
clock-latency-ns = <500000>;
};
opp02 {
opp-hz = /bits/ 64 <729000000>;
opp-microvolt = <1090000>;
clock-latency-ns = <500000>;
};
opp03 {
opp-hz = /bits/ 64 <960000000>;
opp-microvolt = <1180000>;
clock-latency-ns = <500000>;
};
opp04 {
opp-hz = /bits/ 64 <1200000000>;
opp-microvolt = <1330000>;
clock-latency-ns = <500000>;
};
};
gic: interrupt-controller@f6801000 { gic: interrupt-controller@f6801000 {
compatible = "arm,gic-400"; compatible = "arm,gic-400";
reg = <0x0 0xf6801000 0 0x1000>, /* GICD */ reg = <0x0 0xf6801000 0 0x1000>, /* GICD */
...@@ -169,6 +212,11 @@ soc { ...@@ -169,6 +212,11 @@ soc {
#size-cells = <2>; #size-cells = <2>;
ranges; ranges;
sram: sram@fff80000 {
compatible = "hisilicon,hi6220-sramctrl", "syscon";
reg = <0x0 0xfff80000 0x0 0x12000>;
};
ao_ctrl: ao_ctrl@f7800000 { ao_ctrl: ao_ctrl@f7800000 {
compatible = "hisilicon,hi6220-aoctrl", "syscon"; compatible = "hisilicon,hi6220-aoctrl", "syscon";
reg = <0x0 0xf7800000 0x0 0x2000>; reg = <0x0 0xf7800000 0x0 0x2000>;
...@@ -194,6 +242,14 @@ pm_ctrl: pm_ctrl@f7032000 { ...@@ -194,6 +242,14 @@ pm_ctrl: pm_ctrl@f7032000 {
#clock-cells = <1>; #clock-cells = <1>;
}; };
stub_clock: stub_clock {
compatible = "hisilicon,hi6220-stub-clk";
hisilicon,hi6220-clk-sram = <&sram>;
#clock-cells = <1>;
mbox-names = "mbox-tx";
mboxes = <&mailbox 1 0 11>;
};
uart0: uart@f8015000 { /* console */ uart0: uart@f8015000 { /* console */
compatible = "arm,pl011", "arm,primecell"; compatible = "arm,pl011", "arm,primecell";
reg = <0x0 0xf8015000 0x0 0x1000>; reg = <0x0 0xf8015000 0x0 0x1000>;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment