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