diff options
author | Lukasz Majewski <l.majewski@samsung.com> | 2013-12-20 09:24:55 -0500 |
---|---|---|
committer | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2014-01-16 20:00:45 -0500 |
commit | 4f11b85a5f2cc279860da3b9977a9586ff2df167 (patch) | |
tree | edb4ac7c49b97b742d6cf221873d92289cb5a5c6 /drivers/thermal | |
parent | d2228b91fc7709fddeb34450c0ce059fe0a19c60 (diff) |
thermal: exynos: boost: Automatic enable/disable of BOOST feature (at Exynos4412)
This patch provides auto disable/enable operation for boost. It uses already
present thermal infrastructure to provide BOOST hysteresis.
The TMU data is modified to work properly with or without BOOST.
Hence, the two first trip points with corresponding clip frequencies are
adjusted.
The first one is reduced from 85 to 70 degrees and the clip frequency is
increased to 1.4 GHz from 800 MHz. This trip point is in fact responsible
for providing BOOST hysteresis. When temperature exceeds 70 deg, the maximal
non BOOST frequency for Exynos4412 is imposed.
Since the first trigger level has been "stolen" for BOOST, the second one
needs to be a compromise for the previously used two for non BOOST
configuration. The 95 deg with modified clip freq (to 400 MHz) should provide
a good balance between cooling down the overheated device and throughput on
an acceptable level.
Two last trigger levels are not modified since, they cause platform shutdown
on emergency overheat to happen.
The third trip point passage results in SW managed shut down of the system.
If the last trip point is crossed, the PMU HW generates the power off
signal.
Signed-off-by: Lukasz Majewski <l.majewski@samsung.com>
Signed-off-by: Myungjoo Ham <myungjoo.ham@samsung.com>
Acked-by: Eduardo Valentin <eduardo.valentin@ti.com>
Reviewed-by: Zhang Rui <rui.zhang@intel.com>
[rjw: Changelog]
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Diffstat (limited to 'drivers/thermal')
-rw-r--r-- | drivers/thermal/samsung/exynos_tmu_data.c | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/drivers/thermal/samsung/exynos_tmu_data.c b/drivers/thermal/samsung/exynos_tmu_data.c index 073c292baa53..476b768c633e 100644 --- a/drivers/thermal/samsung/exynos_tmu_data.c +++ b/drivers/thermal/samsung/exynos_tmu_data.c | |||
@@ -131,8 +131,8 @@ static const struct exynos_tmu_registers exynos4412_tmu_registers = { | |||
131 | 131 | ||
132 | #define EXYNOS4412_TMU_DATA \ | 132 | #define EXYNOS4412_TMU_DATA \ |
133 | .threshold_falling = 10, \ | 133 | .threshold_falling = 10, \ |
134 | .trigger_levels[0] = 85, \ | 134 | .trigger_levels[0] = 70, \ |
135 | .trigger_levels[1] = 103, \ | 135 | .trigger_levels[1] = 95, \ |
136 | .trigger_levels[2] = 110, \ | 136 | .trigger_levels[2] = 110, \ |
137 | .trigger_levels[3] = 120, \ | 137 | .trigger_levels[3] = 120, \ |
138 | .trigger_enable[0] = true, \ | 138 | .trigger_enable[0] = true, \ |
@@ -155,12 +155,12 @@ static const struct exynos_tmu_registers exynos4412_tmu_registers = { | |||
155 | .second_point_trim = 85, \ | 155 | .second_point_trim = 85, \ |
156 | .default_temp_offset = 50, \ | 156 | .default_temp_offset = 50, \ |
157 | .freq_tab[0] = { \ | 157 | .freq_tab[0] = { \ |
158 | .freq_clip_max = 800 * 1000, \ | 158 | .freq_clip_max = 1400 * 1000, \ |
159 | .temp_level = 85, \ | 159 | .temp_level = 70, \ |
160 | }, \ | 160 | }, \ |
161 | .freq_tab[1] = { \ | 161 | .freq_tab[1] = { \ |
162 | .freq_clip_max = 200 * 1000, \ | 162 | .freq_clip_max = 400 * 1000, \ |
163 | .temp_level = 103, \ | 163 | .temp_level = 95, \ |
164 | }, \ | 164 | }, \ |
165 | .freq_tab_count = 2, \ | 165 | .freq_tab_count = 2, \ |
166 | .registers = &exynos4412_tmu_registers, \ | 166 | .registers = &exynos4412_tmu_registers, \ |