2013-06-24 17:50:48 +07:00
|
|
|
* Exynos Thermal Management Unit (TMU)
|
|
|
|
|
|
|
|
** Required properties:
|
|
|
|
|
|
|
|
- compatible : One of the following:
|
2014-07-01 07:33:19 +07:00
|
|
|
"samsung,exynos3250-tmu"
|
2013-06-24 17:50:48 +07:00
|
|
|
"samsung,exynos4412-tmu"
|
|
|
|
"samsung,exynos4210-tmu"
|
|
|
|
"samsung,exynos5250-tmu"
|
2013-12-20 19:19:10 +07:00
|
|
|
"samsung,exynos5260-tmu"
|
2013-12-19 13:06:31 +07:00
|
|
|
"samsung,exynos5420-tmu" for TMU channel 0, 1 on Exynos5420
|
|
|
|
"samsung,exynos5420-tmu-ext-triminfo" for TMU channels 2, 3 and 4
|
|
|
|
Exynos5420 (Must pass triminfo base and triminfo clock)
|
2016-02-18 12:14:18 +07:00
|
|
|
"samsung,exynos5433-tmu"
|
2015-01-27 12:48:21 +07:00
|
|
|
"samsung,exynos7-tmu"
|
2013-06-24 17:50:48 +07:00
|
|
|
- reg : Address range of the thermal registers. For soc's which has multiple
|
|
|
|
instances of TMU and some registers are shared across all TMU's like
|
|
|
|
interrupt related then 2 set of register has to supplied. First set
|
2013-12-19 13:06:08 +07:00
|
|
|
belongs to register set of TMU instance and second set belongs to
|
|
|
|
registers shared with the TMU instance.
|
2013-12-19 13:06:31 +07:00
|
|
|
|
|
|
|
NOTE: On Exynos5420, the TRIMINFO register is misplaced for TMU
|
|
|
|
channels 2, 3 and 4
|
|
|
|
Use "samsung,exynos5420-tmu-ext-triminfo" in cases, there is a misplaced
|
|
|
|
register, also provide clock to access that base.
|
|
|
|
|
|
|
|
TRIMINFO at 0x1006c000 contains data for TMU channel 3
|
|
|
|
TRIMINFO at 0x100a0000 contains data for TMU channel 4
|
|
|
|
TRIMINFO at 0x10068000 contains data for TMU channel 2
|
|
|
|
|
2013-06-24 17:50:48 +07:00
|
|
|
- interrupts : Should contain interrupt for thermal system
|
2013-12-19 13:06:31 +07:00
|
|
|
- clocks : The main clocks for TMU device
|
|
|
|
-- 1. operational clock for TMU channel
|
|
|
|
-- 2. optional clock to access the shared registers of TMU channel
|
2015-01-27 12:48:21 +07:00
|
|
|
-- 3. optional special clock for functional operation
|
2013-06-24 17:50:48 +07:00
|
|
|
- clock-names : Thermal system clock name
|
2013-12-19 13:06:31 +07:00
|
|
|
-- "tmu_apbif" operational clock for current TMU channel
|
|
|
|
-- "tmu_triminfo_apbif" clock to access the shared triminfo register
|
|
|
|
for current TMU channel
|
2015-01-27 12:48:21 +07:00
|
|
|
-- "tmu_sclk" clock for functional operation of the current TMU
|
|
|
|
channel
|
2016-02-18 12:14:19 +07:00
|
|
|
|
|
|
|
The Exynos TMU supports generating interrupts when reaching given
|
|
|
|
temperature thresholds. Number of supported thermal trip points depends
|
|
|
|
on the SoC (only first trip points defined in DT will be configured):
|
|
|
|
- most of SoC: 4
|
|
|
|
- samsung,exynos5433-tmu: 8
|
|
|
|
- samsung,exynos7-tmu: 8
|
|
|
|
|
2016-02-19 01:19:09 +07:00
|
|
|
** Optional properties:
|
|
|
|
|
|
|
|
- vtmu-supply: This entry is optional and provides the regulator node supplying
|
|
|
|
voltage to TMU. If needed this entry can be placed inside
|
|
|
|
board/platform specific dts file.
|
|
|
|
|
2013-06-24 17:50:48 +07:00
|
|
|
Example 1):
|
|
|
|
|
2017-12-22 01:29:17 +07:00
|
|
|
tmu@100c0000 {
|
2013-06-24 17:50:48 +07:00
|
|
|
compatible = "samsung,exynos4412-tmu";
|
|
|
|
interrupt-parent = <&combiner>;
|
|
|
|
reg = <0x100C0000 0x100>;
|
|
|
|
interrupts = <2 4>;
|
|
|
|
clocks = <&clock 383>;
|
|
|
|
clock-names = "tmu_apbif";
|
|
|
|
vtmu-supply = <&tmu_regulator_node>;
|
2018-03-06 21:43:54 +07:00
|
|
|
#thermal-sensor-cells = <0>;
|
2013-06-24 17:50:48 +07:00
|
|
|
};
|
|
|
|
|
2018-04-26 18:21:12 +07:00
|
|
|
Example 2): (In case of Exynos5420 "with misplaced TRIMINFO register")
|
2013-12-19 13:06:31 +07:00
|
|
|
tmu_cpu2: tmu@10068000 {
|
|
|
|
compatible = "samsung,exynos5420-tmu-ext-triminfo";
|
|
|
|
reg = <0x10068000 0x100>, <0x1006c000 0x4>;
|
|
|
|
interrupts = <0 184 0>;
|
|
|
|
clocks = <&clock 318>, <&clock 318>;
|
|
|
|
clock-names = "tmu_apbif", "tmu_triminfo_apbif";
|
2018-03-06 21:43:54 +07:00
|
|
|
#thermal-sensor-cells = <0>;
|
2013-12-19 13:06:31 +07:00
|
|
|
};
|
|
|
|
|
|
|
|
tmu_cpu3: tmu@1006c000 {
|
|
|
|
compatible = "samsung,exynos5420-tmu-ext-triminfo";
|
|
|
|
reg = <0x1006c000 0x100>, <0x100a0000 0x4>;
|
|
|
|
interrupts = <0 185 0>;
|
|
|
|
clocks = <&clock 318>, <&clock 319>;
|
|
|
|
clock-names = "tmu_apbif", "tmu_triminfo_apbif";
|
2018-03-06 21:43:54 +07:00
|
|
|
#thermal-sensor-cells = <0>;
|
2013-12-19 13:06:31 +07:00
|
|
|
};
|
|
|
|
|
|
|
|
tmu_gpu: tmu@100a0000 {
|
|
|
|
compatible = "samsung,exynos5420-tmu-ext-triminfo";
|
|
|
|
reg = <0x100a0000 0x100>, <0x10068000 0x4>;
|
|
|
|
interrupts = <0 215 0>;
|
|
|
|
clocks = <&clock 319>, <&clock 318>;
|
|
|
|
clock-names = "tmu_apbif", "tmu_triminfo_apbif";
|
2018-03-06 21:43:54 +07:00
|
|
|
#thermal-sensor-cells = <0>;
|
2013-12-19 13:06:31 +07:00
|
|
|
};
|
|
|
|
|
2013-06-24 17:50:48 +07:00
|
|
|
Note: For multi-instance tmu each instance should have an alias correctly
|
|
|
|
numbered in "aliases" node.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
|
|
|
|
aliases {
|
|
|
|
tmuctrl0 = &tmuctrl_0;
|
|
|
|
tmuctrl1 = &tmuctrl_1;
|
|
|
|
tmuctrl2 = &tmuctrl_2;
|
|
|
|
};
|