Merge branch 'parisc-5.2-3' of git://git.kernel.org/pub/scm/linux/kernel/git/deller...
[platform/kernel/linux-starfive.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 530 to 923
50  */
51 static const int
52 omap4430_adc_to_temp[OMAP4430_ADC_END_VALUE - OMAP4430_ADC_START_VALUE + 1] = {
53         -38000, -35000, -34000, -32000, -30000, -28000, -26000, -24000, -22000,
54         -20000, -18000, -17000, -15000, -13000, -12000, -10000, -8000, -6000,
55         -5000, -3000, -1000, 0, 2000, 3000, 5000, 6000, 8000, 10000, 12000,
56         13000, 15000, 17000, 19000, 21000, 23000, 25000, 27000, 28000, 30000,
57         32000, 33000, 35000, 37000, 38000, 40000, 42000, 43000, 45000, 47000,
58         48000, 50000, 52000, 53000, 55000, 57000, 58000, 60000, 62000, 64000,
59         66000, 68000, 70000, 71000, 73000, 75000, 77000, 78000, 80000, 82000,
60         83000, 85000, 87000, 88000, 90000, 92000, 93000, 95000, 97000, 98000,
61         100000, 102000, 103000, 105000, 107000, 109000, 111000, 113000, 115000,
62         117000, 118000, 120000, 122000, 123000,
63 };
64
65 /* OMAP4430 data */
66 const struct ti_bandgap_data omap4430_data = {
67         .features = TI_BANDGAP_FEATURE_MODE_CONFIG |
68                         TI_BANDGAP_FEATURE_CLK_CTRL |
69                         TI_BANDGAP_FEATURE_POWER_SWITCH,
70         .fclock_name = "bandgap_fclk",
71         .div_ck_name = "bandgap_fclk",
72         .conv_table = omap4430_adc_to_temp,
73         .adc_start_val = OMAP4430_ADC_START_VALUE,
74         .adc_end_val = OMAP4430_ADC_END_VALUE,
75         .expose_sensor = ti_thermal_expose_sensor,
76         .remove_sensor = ti_thermal_remove_sensor,
77         .sensors = {
78                 {
79                 .registers = &omap4430_mpu_temp_sensor_registers,
80                 .ts_data = &omap4430_mpu_temp_sensor_data,
81                 .domain = "cpu",
82                 .slope_pcb = OMAP_GRADIENT_SLOPE_W_PCB_4430,
83                 .constant_pcb = OMAP_GRADIENT_CONST_W_PCB_4430,
84                 .register_cooling = ti_thermal_register_cpu_cooling,
85                 .unregister_cooling = ti_thermal_unregister_cpu_cooling,
86                 },
87         },
88         .sensor_count = 1,
89 };
90 /*
91  * OMAP4460 has one instance of thermal sensor for MPU
92  * need to describe the individual bit fields
93  */
94 static struct temp_sensor_registers
95 omap4460_mpu_temp_sensor_registers = {
96         .temp_sensor_ctrl = OMAP4460_TEMP_SENSOR_CTRL_OFFSET,
97         .bgap_tempsoff_mask = OMAP4460_BGAP_TEMPSOFF_MASK,
98         .bgap_soc_mask = OMAP4460_BGAP_TEMP_SENSOR_SOC_MASK,
99         .bgap_eocz_mask = OMAP4460_BGAP_TEMP_SENSOR_EOCZ_MASK,
100         .bgap_dtemp_mask = OMAP4460_BGAP_TEMP_SENSOR_DTEMP_MASK,
101
102         .bgap_mask_ctrl = OMAP4460_BGAP_CTRL_OFFSET,
103         .mask_hot_mask = OMAP4460_MASK_HOT_MASK,
104         .mask_cold_mask = OMAP4460_MASK_COLD_MASK,
105
106         .bgap_mode_ctrl = OMAP4460_BGAP_CTRL_OFFSET,
107         .mode_ctrl_mask = OMAP4460_SINGLE_MODE_MASK,
108
109         .bgap_counter = OMAP4460_BGAP_COUNTER_OFFSET,
110         .counter_mask = OMAP4460_COUNTER_MASK,
111
112         .bgap_threshold = OMAP4460_BGAP_THRESHOLD_OFFSET,
113         .threshold_thot_mask = OMAP4460_T_HOT_MASK,
114         .threshold_tcold_mask = OMAP4460_T_COLD_MASK,
115
116         .tshut_threshold = OMAP4460_BGAP_TSHUT_OFFSET,
117         .tshut_hot_mask = OMAP4460_TSHUT_HOT_MASK,
118         .tshut_cold_mask = OMAP4460_TSHUT_COLD_MASK,
119
120         .bgap_status = OMAP4460_BGAP_STATUS_OFFSET,
121         .status_hot_mask = OMAP4460_HOT_FLAG_MASK,
122         .status_cold_mask = OMAP4460_COLD_FLAG_MASK,
123
124         .bgap_efuse = OMAP4460_FUSE_OPP_BGAP,
125 };
126
127 /* Thresholds and limits for OMAP4460 MPU temperature sensor */
128 static struct temp_sensor_data omap4460_mpu_temp_sensor_data = {
129         .tshut_hot = OMAP4460_TSHUT_HOT,
130         .tshut_cold = OMAP4460_TSHUT_COLD,
131         .t_hot = OMAP4460_T_HOT,
132         .t_cold = OMAP4460_T_COLD,
133         .min_freq = OMAP4460_MIN_FREQ,
134         .max_freq = OMAP4460_MAX_FREQ,
135 };
136
137 /*
138  * Temperature values in milli degree celsius
139  * ADC code values from 530 to 923
140  */
141 static const int
142 omap4460_adc_to_temp[OMAP4460_ADC_END_VALUE - OMAP4460_ADC_START_VALUE + 1] = {
143         -40000, -40000, -40000, -40000, -39800, -39400, -39000, -38600, -38200,
144         -37800, -37300, -36800, -36400, -36000, -35600, -35200, -34800,
145         -34300, -33800, -33400, -33000, -32600, -32200, -31800, -31300,
146         -30800, -30400, -30000, -29600, -29200, -28700, -28200, -27800,
147         -27400, -27000, -26600, -26200, -25700, -25200, -24800, -24400,
148         -24000, -23600, -23200, -22700, -22200, -21800, -21400, -21000,
149         -20600, -20200, -19700, -19200, -18800, -18400, -18000, -17600,
150         -17200, -16700, -16200, -15800, -15400, -15000, -14600, -14200,
151         -13700, -13200, -12800, -12400, -12000, -11600, -11200, -10700,
152         -10200, -9800, -9400, -9000, -8600, -8200, -7700, -7200, -6800,
153         -6400, -6000, -5600, -5200, -4800, -4300, -3800, -3400, -3000,
154         -2600, -2200, -1800, -1300, -800, -400, 0, 400, 800, 1200, 1600,
155         2100, 2600, 3000, 3400, 3800, 4200, 4600, 5100, 5600, 6000, 6400,
156         6800, 7200, 7600, 8000, 8500, 9000, 9400, 9800, 10200, 10600, 11000,
157         11400, 11900, 12400, 12800, 13200, 13600, 14000, 14400, 14800,
158         15300, 15800, 16200, 16600, 17000, 17400, 17800, 18200, 18700,
159         19200, 19600, 20000, 20400, 20800, 21200, 21600, 22100, 22600,
160         23000, 23400, 23800, 24200, 24600, 25000, 25400, 25900, 26400,
161         26800, 27200, 27600, 28000, 28400, 28800, 29300, 29800, 30200,
162         30600, 31000, 31400, 31800, 32200, 32600, 33100, 33600, 34000,
163         34400, 34800, 35200, 35600, 36000, 36400, 36800, 37300, 37800,
164         38200, 38600, 39000, 39400, 39800, 40200, 40600, 41100, 41600,
165         42000, 42400, 42800, 43200, 43600, 44000, 44400, 44800, 45300,
166         45800, 46200, 46600, 47000, 47400, 47800, 48200, 48600, 49000,
167         49500, 50000, 50400, 50800, 51200, 51600, 52000, 52400, 52800,
168         53200, 53700, 54200, 54600, 55000, 55400, 55800, 56200, 56600,
169         57000, 57400, 57800, 58200, 58700, 59200, 59600, 60000, 60400,
170         60800, 61200, 61600, 62000, 62400, 62800, 63300, 63800, 64200,
171         64600, 65000, 65400, 65800, 66200, 66600, 67000, 67400, 67800,
172         68200, 68700, 69200, 69600, 70000, 70400, 70800, 71200, 71600,
173         72000, 72400, 72800, 73200, 73600, 74100, 74600, 75000, 75400,
174         75800, 76200, 76600, 77000, 77400, 77800, 78200, 78600, 79000,
175         79400, 79800, 80300, 80800, 81200, 81600, 82000, 82400, 82800,
176         83200, 83600, 84000, 84400, 84800, 85200, 85600, 86000, 86400,
177         86800, 87300, 87800, 88200, 88600, 89000, 89400, 89800, 90200,
178         90600, 91000, 91400, 91800, 92200, 92600, 93000, 93400, 93800,
179         94200, 94600, 95000, 95500, 96000, 96400, 96800, 97200, 97600,
180         98000, 98400, 98800, 99200, 99600, 100000, 100400, 100800, 101200,
181         101600, 102000, 102400, 102800, 103200, 103600, 104000, 104400,
182         104800, 105200, 105600, 106100, 106600, 107000, 107400, 107800,
183         108200, 108600, 109000, 109400, 109800, 110200, 110600, 111000,
184         111400, 111800, 112200, 112600, 113000, 113400, 113800, 114200,
185         114600, 115000, 115400, 115800, 116200, 116600, 117000, 117400,
186         117800, 118200, 118600, 119000, 119400, 119800, 120200, 120600,
187         121000, 121400, 121800, 122200, 122600, 123000, 123400, 123800, 124200,
188         124600, 124900, 125000, 125000, 125000, 125000
189 };
190
191 /* OMAP4460 data */
192 const struct ti_bandgap_data omap4460_data = {
193         .features = TI_BANDGAP_FEATURE_TSHUT |
194                         TI_BANDGAP_FEATURE_TSHUT_CONFIG |
195                         TI_BANDGAP_FEATURE_TALERT |
196                         TI_BANDGAP_FEATURE_MODE_CONFIG |
197                         TI_BANDGAP_FEATURE_POWER_SWITCH |
198                         TI_BANDGAP_FEATURE_CLK_CTRL |
199                         TI_BANDGAP_FEATURE_COUNTER,
200         .fclock_name = "bandgap_ts_fclk",
201         .div_ck_name = "div_ts_ck",
202         .conv_table = omap4460_adc_to_temp,
203         .adc_start_val = OMAP4460_ADC_START_VALUE,
204         .adc_end_val = OMAP4460_ADC_END_VALUE,
205         .expose_sensor = ti_thermal_expose_sensor,
206         .remove_sensor = ti_thermal_remove_sensor,
207         .report_temperature = ti_thermal_report_sensor_temperature,
208         .sensors = {
209                 {
210                 .registers = &omap4460_mpu_temp_sensor_registers,
211                 .ts_data = &omap4460_mpu_temp_sensor_data,
212                 .domain = "cpu",
213                 .slope_pcb = OMAP_GRADIENT_SLOPE_W_PCB_4460,
214                 .constant_pcb = OMAP_GRADIENT_CONST_W_PCB_4460,
215                 .register_cooling = ti_thermal_register_cpu_cooling,
216                 .unregister_cooling = ti_thermal_unregister_cpu_cooling,
217                 },
218         },
219         .sensor_count = 1,
220 };
221
222 /* OMAP4470 data */
223 const struct ti_bandgap_data omap4470_data = {
224         .features = TI_BANDGAP_FEATURE_TSHUT |
225                         TI_BANDGAP_FEATURE_TSHUT_CONFIG |
226                         TI_BANDGAP_FEATURE_TALERT |
227                         TI_BANDGAP_FEATURE_MODE_CONFIG |
228                         TI_BANDGAP_FEATURE_POWER_SWITCH |
229                         TI_BANDGAP_FEATURE_CLK_CTRL |
230                         TI_BANDGAP_FEATURE_COUNTER,
231         .fclock_name = "bandgap_ts_fclk",
232         .div_ck_name = "div_ts_ck",
233         .conv_table = omap4460_adc_to_temp,
234         .adc_start_val = OMAP4460_ADC_START_VALUE,
235         .adc_end_val = OMAP4460_ADC_END_VALUE,
236         .expose_sensor = ti_thermal_expose_sensor,
237         .remove_sensor = ti_thermal_remove_sensor,
238         .report_temperature = ti_thermal_report_sensor_temperature,
239         .sensors = {
240                 {
241                 .registers = &omap4460_mpu_temp_sensor_registers,
242                 .ts_data = &omap4460_mpu_temp_sensor_data,
243                 .domain = "cpu",
244                 .slope_pcb = OMAP_GRADIENT_SLOPE_W_PCB_4470,
245                 .constant_pcb = OMAP_GRADIENT_CONST_W_PCB_4470,
246                 .register_cooling = ti_thermal_register_cpu_cooling,
247                 .unregister_cooling = ti_thermal_unregister_cpu_cooling,
248                 },
249         },
250         .sensor_count = 1,
251 };