GNU Linux-libre 4.19.207-gnu1
[releases.git] / drivers / thermal / ti-soc-thermal / omap4-thermal-data.c
1 /*
2  * OMAP4 thermal driver.
3  *
4  * Copyright (C) 2011-2012 Texas Instruments Inc.
5  * Contact:
6  *      Eduardo Valentin <eduardo.valentin@ti.com>
7  *
8  * This software is licensed under the terms of the GNU General Public
9  * License version 2, as published by the Free Software Foundation, and
10  * may be copied, distributed, and modified under those terms.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15  * GNU General Public License for more details.
16  *
17  */
18
19 #include "ti-thermal.h"
20 #include "ti-bandgap.h"
21 #include "omap4xxx-bandgap.h"
22
23 /*
24  * OMAP4430 has one instance of thermal sensor for MPU
25  * need to describe the individual bit fields
26  */
27 static struct temp_sensor_registers
28 omap4430_mpu_temp_sensor_registers = {
29         .temp_sensor_ctrl = OMAP4430_TEMP_SENSOR_CTRL_OFFSET,
30         .bgap_tempsoff_mask = OMAP4430_BGAP_TEMPSOFF_MASK,
31         .bgap_soc_mask = OMAP4430_BGAP_TEMP_SENSOR_SOC_MASK,
32         .bgap_eocz_mask = OMAP4430_BGAP_TEMP_SENSOR_EOCZ_MASK,
33         .bgap_dtemp_mask = OMAP4430_BGAP_TEMP_SENSOR_DTEMP_MASK,
34
35         .bgap_mode_ctrl = OMAP4430_TEMP_SENSOR_CTRL_OFFSET,
36         .mode_ctrl_mask = OMAP4430_SINGLE_MODE_MASK,
37
38         .bgap_efuse = OMAP4430_FUSE_OPP_BGAP,
39 };
40
41 /* Thresholds and limits for OMAP4430 MPU temperature sensor */
42 static struct temp_sensor_data omap4430_mpu_temp_sensor_data = {
43         .min_freq = OMAP4430_MIN_FREQ,
44         .max_freq = OMAP4430_MAX_FREQ,
45 };
46
47 /*
48  * Temperature values in milli degree celsius
49  * ADC code values from 13 to 107, see TRM
50  * "18.4.10.2.3 ADC Codes Versus Temperature".
51  */
52 static const int
53 omap4430_adc_to_temp[OMAP4430_ADC_END_VALUE - OMAP4430_ADC_START_VALUE + 1] = {
54         -40000, -38000, -35000, -34000, -32000, -30000, -28000, -26000, -24000,
55         -22000, -20000, -18500, -17000, -15000, -13500, -12000, -10000, -8000,
56         -6500, -5000, -3500, -1500, 0, 2000, 3500, 5000, 6500, 8500, 10000,
57         12000, 13500, 15000, 17000, 19000, 21000, 23000, 25000, 27000, 28500,
58         30000, 32000, 33500, 35000, 37000, 38500, 40000, 42000, 43500, 45000,
59         47000, 48500, 50000, 52000, 53500, 55000, 57000, 58500, 60000, 62000,
60         64000, 66000, 68000, 70000, 71500, 73500, 75000, 77000, 78500, 80000,
61         82000, 83500, 85000, 87000, 88500, 90000, 92000, 93500, 95000, 97000,
62         98500, 100000, 102000, 103500, 105000, 107000, 109000, 111000, 113000,
63         115000, 117000, 118500, 120000, 122000, 123500, 125000,
64 };
65
66 /* OMAP4430 data */
67 const struct ti_bandgap_data omap4430_data = {
68         .features = TI_BANDGAP_FEATURE_MODE_CONFIG |
69                         TI_BANDGAP_FEATURE_CLK_CTRL |
70                         TI_BANDGAP_FEATURE_POWER_SWITCH,
71         .fclock_name = "bandgap_fclk",
72         .div_ck_name = "bandgap_fclk",
73         .conv_table = omap4430_adc_to_temp,
74         .adc_start_val = OMAP4430_ADC_START_VALUE,
75         .adc_end_val = OMAP4430_ADC_END_VALUE,
76         .expose_sensor = ti_thermal_expose_sensor,
77         .remove_sensor = ti_thermal_remove_sensor,
78         .sensors = {
79                 {
80                 .registers = &omap4430_mpu_temp_sensor_registers,
81                 .ts_data = &omap4430_mpu_temp_sensor_data,
82                 .domain = "cpu",
83                 .slope_pcb = OMAP_GRADIENT_SLOPE_W_PCB_4430,
84                 .constant_pcb = OMAP_GRADIENT_CONST_W_PCB_4430,
85                 .register_cooling = ti_thermal_register_cpu_cooling,
86                 .unregister_cooling = ti_thermal_unregister_cpu_cooling,
87                 },
88         },
89         .sensor_count = 1,
90 };
91 /*
92  * OMAP4460 has one instance of thermal sensor for MPU
93  * need to describe the individual bit fields
94  */
95 static struct temp_sensor_registers
96 omap4460_mpu_temp_sensor_registers = {
97         .temp_sensor_ctrl = OMAP4460_TEMP_SENSOR_CTRL_OFFSET,
98         .bgap_tempsoff_mask = OMAP4460_BGAP_TEMPSOFF_MASK,
99         .bgap_soc_mask = OMAP4460_BGAP_TEMP_SENSOR_SOC_MASK,
100         .bgap_eocz_mask = OMAP4460_BGAP_TEMP_SENSOR_EOCZ_MASK,
101         .bgap_dtemp_mask = OMAP4460_BGAP_TEMP_SENSOR_DTEMP_MASK,
102
103         .bgap_mask_ctrl = OMAP4460_BGAP_CTRL_OFFSET,
104         .mask_hot_mask = OMAP4460_MASK_HOT_MASK,
105         .mask_cold_mask = OMAP4460_MASK_COLD_MASK,
106
107         .bgap_mode_ctrl = OMAP4460_BGAP_CTRL_OFFSET,
108         .mode_ctrl_mask = OMAP4460_SINGLE_MODE_MASK,
109
110         .bgap_counter = OMAP4460_BGAP_COUNTER_OFFSET,
111         .counter_mask = OMAP4460_COUNTER_MASK,
112
113         .bgap_threshold = OMAP4460_BGAP_THRESHOLD_OFFSET,
114         .threshold_thot_mask = OMAP4460_T_HOT_MASK,
115         .threshold_tcold_mask = OMAP4460_T_COLD_MASK,
116
117         .tshut_threshold = OMAP4460_BGAP_TSHUT_OFFSET,
118         .tshut_hot_mask = OMAP4460_TSHUT_HOT_MASK,
119         .tshut_cold_mask = OMAP4460_TSHUT_COLD_MASK,
120
121         .bgap_status = OMAP4460_BGAP_STATUS_OFFSET,
122         .status_hot_mask = OMAP4460_HOT_FLAG_MASK,
123         .status_cold_mask = OMAP4460_COLD_FLAG_MASK,
124
125         .bgap_efuse = OMAP4460_FUSE_OPP_BGAP,
126 };
127
128 /* Thresholds and limits for OMAP4460 MPU temperature sensor */
129 static struct temp_sensor_data omap4460_mpu_temp_sensor_data = {
130         .tshut_hot = OMAP4460_TSHUT_HOT,
131         .tshut_cold = OMAP4460_TSHUT_COLD,
132         .t_hot = OMAP4460_T_HOT,
133         .t_cold = OMAP4460_T_COLD,
134         .min_freq = OMAP4460_MIN_FREQ,
135         .max_freq = OMAP4460_MAX_FREQ,
136 };
137
138 /*
139  * Temperature values in milli degree celsius
140  * ADC code values from 530 to 923
141  */
142 static const int
143 omap4460_adc_to_temp[OMAP4460_ADC_END_VALUE - OMAP4460_ADC_START_VALUE + 1] = {
144         -40000, -40000, -40000, -40000, -39800, -39400, -39000, -38600, -38200,
145         -37800, -37300, -36800, -36400, -36000, -35600, -35200, -34800,
146         -34300, -33800, -33400, -33000, -32600, -32200, -31800, -31300,
147         -30800, -30400, -30000, -29600, -29200, -28700, -28200, -27800,
148         -27400, -27000, -26600, -26200, -25700, -25200, -24800, -24400,
149         -24000, -23600, -23200, -22700, -22200, -21800, -21400, -21000,
150         -20600, -20200, -19700, -19200, -18800, -18400, -18000, -17600,
151         -17200, -16700, -16200, -15800, -15400, -15000, -14600, -14200,
152         -13700, -13200, -12800, -12400, -12000, -11600, -11200, -10700,
153         -10200, -9800, -9400, -9000, -8600, -8200, -7700, -7200, -6800,
154         -6400, -6000, -5600, -5200, -4800, -4300, -3800, -3400, -3000,
155         -2600, -2200, -1800, -1300, -800, -400, 0, 400, 800, 1200, 1600,
156         2100, 2600, 3000, 3400, 3800, 4200, 4600, 5100, 5600, 6000, 6400,
157         6800, 7200, 7600, 8000, 8500, 9000, 9400, 9800, 10200, 10600, 11000,
158         11400, 11900, 12400, 12800, 13200, 13600, 14000, 14400, 14800,
159         15300, 15800, 16200, 16600, 17000, 17400, 17800, 18200, 18700,
160         19200, 19600, 20000, 20400, 20800, 21200, 21600, 22100, 22600,
161         23000, 23400, 23800, 24200, 24600, 25000, 25400, 25900, 26400,
162         26800, 27200, 27600, 28000, 28400, 28800, 29300, 29800, 30200,
163         30600, 31000, 31400, 31800, 32200, 32600, 33100, 33600, 34000,
164         34400, 34800, 35200, 35600, 36000, 36400, 36800, 37300, 37800,
165         38200, 38600, 39000, 39400, 39800, 40200, 40600, 41100, 41600,
166         42000, 42400, 42800, 43200, 43600, 44000, 44400, 44800, 45300,
167         45800, 46200, 46600, 47000, 47400, 47800, 48200, 48600, 49000,
168         49500, 50000, 50400, 50800, 51200, 51600, 52000, 52400, 52800,
169         53200, 53700, 54200, 54600, 55000, 55400, 55800, 56200, 56600,
170         57000, 57400, 57800, 58200, 58700, 59200, 59600, 60000, 60400,
171         60800, 61200, 61600, 62000, 62400, 62800, 63300, 63800, 64200,
172         64600, 65000, 65400, 65800, 66200, 66600, 67000, 67400, 67800,
173         68200, 68700, 69200, 69600, 70000, 70400, 70800, 71200, 71600,
174         72000, 72400, 72800, 73200, 73600, 74100, 74600, 75000, 75400,
175         75800, 76200, 76600, 77000, 77400, 77800, 78200, 78600, 79000,
176         79400, 79800, 80300, 80800, 81200, 81600, 82000, 82400, 82800,
177         83200, 83600, 84000, 84400, 84800, 85200, 85600, 86000, 86400,
178         86800, 87300, 87800, 88200, 88600, 89000, 89400, 89800, 90200,
179         90600, 91000, 91400, 91800, 92200, 92600, 93000, 93400, 93800,
180         94200, 94600, 95000, 95500, 96000, 96400, 96800, 97200, 97600,
181         98000, 98400, 98800, 99200, 99600, 100000, 100400, 100800, 101200,
182         101600, 102000, 102400, 102800, 103200, 103600, 104000, 104400,
183         104800, 105200, 105600, 106100, 106600, 107000, 107400, 107800,
184         108200, 108600, 109000, 109400, 109800, 110200, 110600, 111000,
185         111400, 111800, 112200, 112600, 113000, 113400, 113800, 114200,
186         114600, 115000, 115400, 115800, 116200, 116600, 117000, 117400,
187         117800, 118200, 118600, 119000, 119400, 119800, 120200, 120600,
188         121000, 121400, 121800, 122200, 122600, 123000, 123400, 123800, 124200,
189         124600, 124900, 125000, 125000, 125000, 125000
190 };
191
192 /* OMAP4460 data */
193 const struct ti_bandgap_data omap4460_data = {
194         .features = TI_BANDGAP_FEATURE_TSHUT |
195                         TI_BANDGAP_FEATURE_TSHUT_CONFIG |
196                         TI_BANDGAP_FEATURE_TALERT |
197                         TI_BANDGAP_FEATURE_MODE_CONFIG |
198                         TI_BANDGAP_FEATURE_POWER_SWITCH |
199                         TI_BANDGAP_FEATURE_CLK_CTRL |
200                         TI_BANDGAP_FEATURE_COUNTER,
201         .fclock_name = "bandgap_ts_fclk",
202         .div_ck_name = "div_ts_ck",
203         .conv_table = omap4460_adc_to_temp,
204         .adc_start_val = OMAP4460_ADC_START_VALUE,
205         .adc_end_val = OMAP4460_ADC_END_VALUE,
206         .expose_sensor = ti_thermal_expose_sensor,
207         .remove_sensor = ti_thermal_remove_sensor,
208         .report_temperature = ti_thermal_report_sensor_temperature,
209         .sensors = {
210                 {
211                 .registers = &omap4460_mpu_temp_sensor_registers,
212                 .ts_data = &omap4460_mpu_temp_sensor_data,
213                 .domain = "cpu",
214                 .slope_pcb = OMAP_GRADIENT_SLOPE_W_PCB_4460,
215                 .constant_pcb = OMAP_GRADIENT_CONST_W_PCB_4460,
216                 .register_cooling = ti_thermal_register_cpu_cooling,
217                 .unregister_cooling = ti_thermal_unregister_cpu_cooling,
218                 },
219         },
220         .sensor_count = 1,
221 };
222
223 /* OMAP4470 data */
224 const struct ti_bandgap_data omap4470_data = {
225         .features = TI_BANDGAP_FEATURE_TSHUT |
226                         TI_BANDGAP_FEATURE_TSHUT_CONFIG |
227                         TI_BANDGAP_FEATURE_TALERT |
228                         TI_BANDGAP_FEATURE_MODE_CONFIG |
229                         TI_BANDGAP_FEATURE_POWER_SWITCH |
230                         TI_BANDGAP_FEATURE_CLK_CTRL |
231                         TI_BANDGAP_FEATURE_COUNTER,
232         .fclock_name = "bandgap_ts_fclk",
233         .div_ck_name = "div_ts_ck",
234         .conv_table = omap4460_adc_to_temp,
235         .adc_start_val = OMAP4460_ADC_START_VALUE,
236         .adc_end_val = OMAP4460_ADC_END_VALUE,
237         .expose_sensor = ti_thermal_expose_sensor,
238         .remove_sensor = ti_thermal_remove_sensor,
239         .report_temperature = ti_thermal_report_sensor_temperature,
240         .sensors = {
241                 {
242                 .registers = &omap4460_mpu_temp_sensor_registers,
243                 .ts_data = &omap4460_mpu_temp_sensor_data,
244                 .domain = "cpu",
245                 .slope_pcb = OMAP_GRADIENT_SLOPE_W_PCB_4470,
246                 .constant_pcb = OMAP_GRADIENT_CONST_W_PCB_4470,
247                 .register_cooling = ti_thermal_register_cpu_cooling,
248                 .unregister_cooling = ti_thermal_unregister_cpu_cooling,
249                 },
250         },
251         .sensor_count = 1,
252 };