mirror of
https://github.com/hanwckf/immortalwrt-mt798x.git
synced 2025-01-10 11:09:57 +08:00
7fb1b00f5f
(cherry picked from commit 0d6e831f2ce450c15341e818f0c84d85e5259eec)
91 lines
2.2 KiB
Diff
91 lines
2.2 KiB
Diff
From d04f7bc8842c0d9951a5740480f864a4f82d6b63 Mon Sep 17 00:00:00 2001
|
|
From: Chen-Yu Tsai <wens@csie.org>
|
|
Date: Sat, 18 Jul 2020 00:00:50 +0800
|
|
Subject: [PATCH] arm64: dts: allwinner: h5: Add trip and cooling maps to CPU
|
|
thermal zones
|
|
|
|
This enables passive cooling by down-regulating CPU voltage and frequency.
|
|
The trip points were copied from the H3.
|
|
|
|
Signed-off-by: Chen-Yu Tsai <wens@csie.org>
|
|
Signed-off-by: Maxime Ripard <maxime@cerno.tech>
|
|
Link: https://lore.kernel.org/r/20200717160053.31191-6-wens@kernel.org
|
|
---
|
|
arch/arm64/boot/dts/allwinner/sun50i-h5.dtsi | 30 ++++++++++++++++++++
|
|
1 file changed, 30 insertions(+)
|
|
|
|
--- a/arch/arm64/boot/dts/allwinner/sun50i-h5.dtsi
|
|
+++ b/arch/arm64/boot/dts/allwinner/sun50i-h5.dtsi
|
|
@@ -42,6 +42,8 @@
|
|
|
|
#include <arm/sunxi-h3-h5.dtsi>
|
|
|
|
+#include <dt-bindings/thermal/thermal.h>
|
|
+
|
|
/ {
|
|
cpus {
|
|
#address-cells = <1>;
|
|
@@ -54,6 +56,7 @@
|
|
enable-method = "psci";
|
|
clocks = <&ccu CLK_CPUX>;
|
|
clock-latency-ns = <244144>; /* 8 32k periods */
|
|
+ #cooling-cells = <2>;
|
|
};
|
|
|
|
cpu1: cpu@1 {
|
|
@@ -63,6 +66,7 @@
|
|
enable-method = "psci";
|
|
clocks = <&ccu CLK_CPUX>;
|
|
clock-latency-ns = <244144>; /* 8 32k periods */
|
|
+ #cooling-cells = <2>;
|
|
};
|
|
|
|
cpu2: cpu@2 {
|
|
@@ -72,6 +76,7 @@
|
|
enable-method = "psci";
|
|
clocks = <&ccu CLK_CPUX>;
|
|
clock-latency-ns = <244144>; /* 8 32k periods */
|
|
+ #cooling-cells = <2>;
|
|
};
|
|
|
|
cpu3: cpu@3 {
|
|
@@ -81,6 +86,7 @@
|
|
enable-method = "psci";
|
|
clocks = <&ccu CLK_CPUX>;
|
|
clock-latency-ns = <244144>; /* 8 32k periods */
|
|
+ #cooling-cells = <2>;
|
|
};
|
|
};
|
|
|
|
@@ -201,6 +207,30 @@
|
|
polling-delay-passive = <0>;
|
|
polling-delay = <0>;
|
|
thermal-sensors = <&ths 0>;
|
|
+
|
|
+ trips {
|
|
+ cpu_hot_trip: cpu-hot {
|
|
+ temperature = <80000>;
|
|
+ hysteresis = <2000>;
|
|
+ type = "passive";
|
|
+ };
|
|
+
|
|
+ cpu_very_hot_trip: cpu-very-hot {
|
|
+ temperature = <100000>;
|
|
+ hysteresis = <0>;
|
|
+ type = "critical";
|
|
+ };
|
|
+ };
|
|
+
|
|
+ cooling-maps {
|
|
+ cpu-hot-limit {
|
|
+ trip = <&cpu_hot_trip>;
|
|
+ cooling-device = <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
|
|
+ <&cpu1 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
|
|
+ <&cpu2 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
|
|
+ <&cpu3 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
|
|
+ };
|
|
+ };
|
|
};
|
|
|
|
gpu_thermal {
|