Donggeun Kim | 9d97e5c | 2011-09-07 18:49:08 +0900 | [diff] [blame^] | 1 | Kernel driver exynos4_tmu |
| 2 | ================= |
| 3 | |
| 4 | Supported chips: |
| 5 | * ARM SAMSUNG EXYNOS4 series of SoC |
| 6 | Prefix: 'exynos4-tmu' |
| 7 | Datasheet: Not publicly available |
| 8 | |
| 9 | Authors: Donggeun Kim <dg77.kim@samsung.com> |
| 10 | |
| 11 | Description |
| 12 | ----------- |
| 13 | |
| 14 | This driver allows to read temperature inside SAMSUNG EXYNOS4 series of SoC. |
| 15 | |
| 16 | The chip only exposes the measured 8-bit temperature code value |
| 17 | through a register. |
| 18 | Temperature can be taken from the temperature code. |
| 19 | There are three equations converting from temperature to temperature code. |
| 20 | |
| 21 | The 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 | |
| 37 | TMU(Thermal Management Unit) in EXYNOS4 generates interrupt |
| 38 | when temperature exceeds pre-defined levels. |
| 39 | The maximum number of configurable threshold is four. |
| 40 | The 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 | |
| 49 | When an interrupt occurs, this driver notify user space of |
| 50 | one of four threshold levels for the interrupt |
| 51 | through kobject_uevent_env and sysfs_notify functions. |
| 52 | Although an interrupt condition for level_0 can be set, |
| 53 | it is not notified to user space through sysfs_notify function. |
| 54 | |
| 55 | Sysfs Interface |
| 56 | --------------- |
| 57 | name name of the temperature sensor |
| 58 | RO |
| 59 | |
| 60 | temp1_input temperature |
| 61 | RO |
| 62 | |
| 63 | temp1_max temperature for level_1 interrupt |
| 64 | RO |
| 65 | |
| 66 | temp1_crit temperature for level_2 interrupt |
| 67 | RO |
| 68 | |
| 69 | temp1_emergency temperature for level_3 interrupt |
| 70 | RO |
| 71 | |
| 72 | temp1_max_alarm alarm for level_1 interrupt |
| 73 | RO |
| 74 | |
| 75 | temp1_crit_alarm |
| 76 | alarm for level_2 interrupt |
| 77 | RO |
| 78 | |
| 79 | temp1_emergency_alarm |
| 80 | alarm for level_3 interrupt |
| 81 | RO |