mm/zsmalloc: allocate exactly size of struct zs_pool
[linux/fpc-iii.git] / drivers / thermal / ti-soc-thermal / ti-thermal.h
blobf8b7ffea6194f25662e5919463896ba936392861
1 /*
2 * OMAP thermal definitions
4 * Copyright (C) 2012 Texas Instruments Incorporated - http://www.ti.com/
5 * Contact:
6 * Eduardo Valentin <eduardo.valentin@ti.com>
8 * This program is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public License
10 * version 2 as published by the Free Software Foundation.
12 * This program is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
20 * 02110-1301 USA
23 #ifndef __TI_THERMAL_H
24 #define __TI_THERMAL_H
26 #include "ti-bandgap.h"
28 /* sensors gradient and offsets */
29 #define OMAP_GRADIENT_SLOPE_4430 0
30 #define OMAP_GRADIENT_CONST_4430 20000
31 #define OMAP_GRADIENT_SLOPE_4460 348
32 #define OMAP_GRADIENT_CONST_4460 -9301
33 #define OMAP_GRADIENT_SLOPE_4470 308
34 #define OMAP_GRADIENT_CONST_4470 -7896
36 #define OMAP_GRADIENT_SLOPE_5430_CPU 65
37 #define OMAP_GRADIENT_CONST_5430_CPU -1791
38 #define OMAP_GRADIENT_SLOPE_5430_GPU 117
39 #define OMAP_GRADIENT_CONST_5430_GPU -2992
41 #define DRA752_GRADIENT_SLOPE 0
42 #define DRA752_GRADIENT_CONST 2000
44 /* PCB sensor calculation constants */
45 #define OMAP_GRADIENT_SLOPE_W_PCB_4430 0
46 #define OMAP_GRADIENT_CONST_W_PCB_4430 20000
47 #define OMAP_GRADIENT_SLOPE_W_PCB_4460 1142
48 #define OMAP_GRADIENT_CONST_W_PCB_4460 -393
49 #define OMAP_GRADIENT_SLOPE_W_PCB_4470 1063
50 #define OMAP_GRADIENT_CONST_W_PCB_4470 -477
52 #define OMAP_GRADIENT_SLOPE_W_PCB_5430_CPU 100
53 #define OMAP_GRADIENT_CONST_W_PCB_5430_CPU 484
54 #define OMAP_GRADIENT_SLOPE_W_PCB_5430_GPU 464
55 #define OMAP_GRADIENT_CONST_W_PCB_5430_GPU -5102
57 #define DRA752_GRADIENT_SLOPE_W_PCB 0
58 #define DRA752_GRADIENT_CONST_W_PCB 2000
60 /* trip points of interest in milicelsius (at hotspot level) */
61 #define OMAP_TRIP_COLD 100000
62 #define OMAP_TRIP_HOT 110000
63 #define OMAP_TRIP_SHUTDOWN 125000
64 #define OMAP_TRIP_NUMBER 2
65 #define OMAP_TRIP_STEP \
66 ((OMAP_TRIP_SHUTDOWN - OMAP_TRIP_HOT) / (OMAP_TRIP_NUMBER - 1))
68 /* Update rates */
69 #define FAST_TEMP_MONITORING_RATE 250
71 /* helper macros */
72 /**
73 * ti_thermal_get_trip_value - returns trip temperature based on index
74 * @i: trip index
76 #define ti_thermal_get_trip_value(i) \
77 (OMAP_TRIP_HOT + ((i) * OMAP_TRIP_STEP))
79 /**
80 * ti_thermal_is_valid_trip - check for trip index
81 * @i: trip index
83 #define ti_thermal_is_valid_trip(trip) \
84 ((trip) >= 0 && (trip) < OMAP_TRIP_NUMBER)
86 #ifdef CONFIG_TI_THERMAL
87 int ti_thermal_expose_sensor(struct ti_bandgap *bgp, int id, char *domain);
88 int ti_thermal_remove_sensor(struct ti_bandgap *bgp, int id);
89 int ti_thermal_report_sensor_temperature(struct ti_bandgap *bgp, int id);
90 int ti_thermal_register_cpu_cooling(struct ti_bandgap *bgp, int id);
91 int ti_thermal_unregister_cpu_cooling(struct ti_bandgap *bgp, int id);
92 #else
93 static inline
94 int ti_thermal_expose_sensor(struct ti_bandgap *bgp, int id, char *domain)
96 return 0;
99 static inline
100 int ti_thermal_remove_sensor(struct ti_bandgap *bgp, int id)
102 return 0;
105 static inline
106 int ti_thermal_report_sensor_temperature(struct ti_bandgap *bgp, int id)
108 return 0;
111 static inline
112 int ti_thermal_register_cpu_cooling(struct ti_bandgap *bgp, int id)
114 return 0;
117 static inline
118 int ti_thermal_unregister_cpu_cooling(struct ti_bandgap *bgp, int id)
120 return 0;
122 #endif
123 #endif