blob: 9010c441696743ec87bec451a71c2b1403c0fa37 [file] [log] [blame]
Amit Daniel Kachhapbeb70b22013-06-24 16:20:49 +05301Kernel driver exynos_tmu
Donggeun Kim9d97e5c2011-09-07 18:49:08 +09002=================
3
4Supported chips:
Amit Daniel Kachhapbeb70b22013-06-24 16:20:49 +05305* ARM SAMSUNG EXYNOS4, EXYNOS5 series of SoC
Donggeun Kim9d97e5c2011-09-07 18:49:08 +09006 Datasheet: Not publicly available
7
8Authors: Donggeun Kim <dg77.kim@samsung.com>
Amit Daniel Kachhapbeb70b22013-06-24 16:20:49 +05309Authors: Amit Daniel <amit.daniel@samsung.com>
Donggeun Kim9d97e5c2011-09-07 18:49:08 +090010
Amit Daniel Kachhapbeb70b22013-06-24 16:20:49 +053011TMU controller Description:
12---------------------------
Donggeun Kim9d97e5c2011-09-07 18:49:08 +090013
Amit Daniel Kachhapbeb70b22013-06-24 16:20:49 +053014This driver allows to read temperature inside SAMSUNG EXYNOS4/5 series of SoC.
Donggeun Kim9d97e5c2011-09-07 18:49:08 +090015
16The chip only exposes the measured 8-bit temperature code value
17through a register.
18Temperature can be taken from the temperature code.
19There are three equations converting from temperature to temperature code.
20
21The three equations are:
22 1. Two point trimming
23 Tc = (T - 25) * (TI2 - TI1) / (85 - 25) + TI1
24
25 2. One point trimming
26 Tc = T + TI1 - 25
27
28 3. No trimming
29 Tc = T + 50
30
31 Tc: Temperature code, T: Temperature,
32 TI1: Trimming info for 25 degree Celsius (stored at TRIMINFO register)
33 Temperature code measured at 25 degree Celsius which is unchanged
34 TI2: Trimming info for 85 degree Celsius (stored at TRIMINFO register)
35 Temperature code measured at 85 degree Celsius which is unchanged
36
Amit Daniel Kachhapbeb70b22013-06-24 16:20:49 +053037TMU(Thermal Management Unit) in EXYNOS4/5 generates interrupt
Donggeun Kim9d97e5c2011-09-07 18:49:08 +090038when temperature exceeds pre-defined levels.
Amit Daniel Kachhapbeb70b22013-06-24 16:20:49 +053039The maximum number of configurable threshold is five.
Donggeun Kim9d97e5c2011-09-07 18:49:08 +090040The threshold levels are defined as follows:
41 Level_0: current temperature > trigger_level_0 + threshold
42 Level_1: current temperature > trigger_level_1 + threshold
43 Level_2: current temperature > trigger_level_2 + threshold
44 Level_3: current temperature > trigger_level_3 + threshold
45
46 The threshold and each trigger_level are set
47 through the corresponding registers.
48
Amit Daniel Kachhapc48cbba2012-08-16 17:11:41 +053049When an interrupt occurs, this driver notify kernel thermal framework
Amit Daniel Kachhapbeb70b22013-06-24 16:20:49 +053050with the function exynos_report_trigger.
Donggeun Kim9d97e5c2011-09-07 18:49:08 +090051Although an interrupt condition for level_0 can be set,
Amit Daniel Kachhapc48cbba2012-08-16 17:11:41 +053052it can be used to synchronize the cooling action.
Amit Daniel Kachhapbeb70b22013-06-24 16:20:49 +053053
54TMU driver description:
55-----------------------
56
57The exynos thermal driver is structured as,
58
59 Kernel Core thermal framework
60 (thermal_core.c, step_wise.c, cpu_cooling.c)
61 ^
62 |
63 |
64TMU configuration data -------> TMU Driver <------> Exynos Core thermal wrapper
65(exynos_tmu_data.c) (exynos_tmu.c) (exynos_thermal_common.c)
66(exynos_tmu_data.h) (exynos_tmu.h) (exynos_thermal_common.h)
67
68a) TMU configuration data: This consist of TMU register offsets/bitfields
69 described through structure exynos_tmu_registers. Also several
70 other platform data (struct exynos_tmu_platform_data) members
71 are used to configure the TMU.
72b) TMU driver: This component initialises the TMU controller and sets different
73 thresholds. It invokes core thermal implementation with the call
74 exynos_report_trigger.
75c) Exynos Core thermal wrapper: This provides 3 wrapper function to use the
76 Kernel core thermal framework. They are exynos_unregister_thermal,
77 exynos_register_thermal and exynos_report_trigger.